C#(DotNet Core) 中用于指针的 volatile Read/Write
volatile Read/Write in C#(DotNet Core) for pointers
平台:Linux
上的 DotNet Core 2
C# 指针取消引用是易失性的还是如何使其成为易失性的?
我们的团队正在研究一些疯狂的东西,需要超低延迟,但仍然需要用 C# 编写。我们需要从共享内存中获取尽可能低延迟的价值,我们将忙于等待。
因此,指向共享内存的指针引用是我想象的最快方式。但真正关心 JIT 会尝试缓存值。
我认为 Volatile.Read(IntPtr) 可能会完成这项工作,但 IntPtr 似乎是一个不可变对象,因此如果我们继续分配新对象,应用程序将产生大量垃圾。
感谢@Eric 指出这不是在制造垃圾。但我的问题仍然存在。 Volatile.Read(IntPtr) 是否会完成这项工作?由于 IntPtr 不是易失性的,但它指向的值是。
还有机会在指针上使用比较和交换功能吗?
unsafe
{
var access = MemoryMappedFile.CreateFromFile("Test.mem");
IntPtr ptr = access.SafeMemoryMappedFileHandle.DangerousGetHandle();
int* p = (int*)ptr.ToPointer();
p++; //How to get value of this p, if the memory will be updated by another process.
}
Volatile.Read(ref *p);
但是你必须保证地址是4字节对齐的。否则读取不会是原子的。
平台:Linux
上的 DotNet Core 2C# 指针取消引用是易失性的还是如何使其成为易失性的?
我们的团队正在研究一些疯狂的东西,需要超低延迟,但仍然需要用 C# 编写。我们需要从共享内存中获取尽可能低延迟的价值,我们将忙于等待。 因此,指向共享内存的指针引用是我想象的最快方式。但真正关心 JIT 会尝试缓存值。
我认为 Volatile.Read(IntPtr) 可能会完成这项工作,但 IntPtr 似乎是一个不可变对象,因此如果我们继续分配新对象,应用程序将产生大量垃圾。
感谢@Eric 指出这不是在制造垃圾。但我的问题仍然存在。 Volatile.Read(IntPtr) 是否会完成这项工作?由于 IntPtr 不是易失性的,但它指向的值是。
还有机会在指针上使用比较和交换功能吗?
unsafe
{
var access = MemoryMappedFile.CreateFromFile("Test.mem");
IntPtr ptr = access.SafeMemoryMappedFileHandle.DangerousGetHandle();
int* p = (int*)ptr.ToPointer();
p++; //How to get value of this p, if the memory will be updated by another process.
}
Volatile.Read(ref *p);
但是你必须保证地址是4字节对齐的。否则读取不会是原子的。