C标题:
__declspec(dllexport) voID SetVolume(BYTE* data,unsigned int wIDth);
C/C++li包装:
voID SetVolume(array<Byte>^ data,UInt32 wIDth) { cli::pin_ptr<BYTE> pdata = &data[0]; pal->SetVolume(pdata,wIDth); }
C# :
public startCalc(){ byte[] voxelArr = file.ReadAllBytes("Filtered.rec"); palw.SetVolume(voxelArr,490); //GC.KeepAlive(voxelArr); makes no sense}
C SetVolume函数启动异步计算. voxelArr不再从被管理方引用,并且被垃圾回收.
在非托管代码完成工作而不将voxelArr声明为全局变量之前,我该如何防止垃圾收集?创建数组的副本不是一个选项,因为真的有很多数据. startCalc()中的活动等待也不好.
解决方法 您可以使用GCHandle.Alloc
(voxelArr,GCHandleType.Pinned
)手动固定阵列,以使GC不会移动或清除. 当您知道方法完成后,您将需要Free句柄,这将需要某种形式的回调才能完成.
总结以上是内存溢出为你收集整理的c# – 防止在非托管代码中使用的托管引用的垃圾收集全部内容,希望文章能够帮你解决c# – 防止在非托管代码中使用的托管引用的垃圾收集所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)