从 .NET 程序集透明地访问本机内存

Access native memory transparently from .NET assembly

本文关键字:访问 本机 内存 透明 NET 程序集      更新时间:2023-10-16

我正在评估为本机应用程序实现插件基础结构的可能性,该基础结构允许用托管代码编写扩展。这些插件将在本机堆上分配的大型浮点缓冲区上运行,这些浮点缓冲区在复制内存占用方面相当昂贵。因此,插件应该能够直接在本机内存上运行。

据我了解

,可以使用不安全代码和指针从托管代码访问本机内存(据我了解,这是 .NET 框架中唯一这样做的规定(。为了简化插件的开发,我宁愿不公开此工件并提供代理机制,以便可以像托管集合一样访问缓冲区。

对于

实现(例如,C++/CLI 互操作层就可以(或特定的 .NET 运行时版本没有任何限制。可以假定缓冲区的大小也是固定的;该插件将仅修改内容。

是否有可能实施满足上述要求的基础架构,如果是,存在哪些选项?

是否有可能实施满足上述要求的基础架构,如果是,存在哪些选项?

您无法

直接将本机数据视为托管数组,但可以通过 C++/CLI 公开一个层,该层允许对该内存进行直接、可索引的访问。

例如,假设您有一个由几百万个双精度浮点值组成的缓冲区。 您可以轻松地制作一个 C++/CLI ref class,通过索引器在该缓冲区上公开一个窗口,甚至更好,作为IList<T>

这可能会允许它像普通IList<T>一样从 C# 使用,而无需复制数据,因为包装类只需要存储缓冲区内存位置。