我正在评估为允许以托管代码编写扩展的本机应用程序实现插件基础结构的可能性。这些插件将在本地堆上分配的大型(-ish)浮点缓冲区上运行,这在复制内存占用方面相当昂贵。因此,插件应该能够直接在本机内存上进行操作。
据我了解,可以通过使用不安全代码和指针从托管代码访问本机内存(据我了解,这是 .NET 框架中唯一这样做的规定)。为了简化插件的开发,我宁愿不公开这个工件并提供代理机制,以便可以像托管集合一样访问缓冲区。
对于实现(例如,C++/CLI 互操作层很好)或特定的 .NET 运行时版本没有限制。缓冲区也可以假定为固定大小;该插件只会修改内容。
是否可以实施满足上述要求的基础设施,如果可以,有哪些选择?