public class Test
{
int m_iInt1; // 0x0
int m_iInt2; // 0x4
}
Run Code Online (Sandbox Code Playgroud)
在 C# 中是否可以访问这样的字段:
var inst = new Test();
unsafe
{
var reference = __makeref(inst);
int int1 = *(int*)(reference + 0x0);
}
Run Code Online (Sandbox Code Playgroud)
我怎样才能做到这一点?
你不能那样做。
我可以
var inst = new Test();
unsafe
{
var reference = __makeref(inst); // could also be retrieved with GCHandle.Alloc
IntPtr ptr = **(IntPtr**)(&reference);
int* x = (int*)ptr;
Console.WriteLine(x[1]); // prints m_iInt1
Console.WriteLine(x[2]); // prints m_iInt2
Console.WriteLine(*(int*)((int)ptr + 0x4)); // same as above
Console.WriteLine(*(int*)((int)ptr + 0x8));
}
Run Code Online (Sandbox Code Playgroud)
我想*(int*)((int)ptr + 0x0)方法表指针如下所述:http://blogs.microsoft.co.il/sasha/2012/03/15/virtual-method-dispatch-and-object-layout-changes-in-clr-40 /和http://yonifedaeli.blogspot.com/2017/03/sync-block-index-sbi-object-header-word.html
这只是出于教育目的,我知道普通软件中不会使用这些东西。这可以用于很多事情,这里不再赘述。
| 归档时间: |
|
| 查看次数: |
1240 次 |
| 最近记录: |