如何通过 C# 中的偏移量访问字段值

Kon*_*rad 3 c# clr

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)

我怎样才能做到这一点?

Kon*_*rad 5

你不能那样做。

我可以

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

这只是出于教育目的,我知道普通软件中不会使用这些东西。这可以用于很多事情,这里不再赘述。