C#处理C++库回调报错_非托管代码传递委托被垃圾回收

如果非托管代码需要多次调用托管代码中的委托,请将委托保存为成员变量。

如果非托管代码需要多次调用托管代码中的回调,请将委托的引用保存为成员变量。否则会出现类似下面的异常:

               检测到 CallbackOnCollectedDelegate
               Message: 对“Demo!SomeNamespace.SomeClass+SomeDelegate::Invoke”类型的已垃圾回收委托进行了回调。这可能会导致应用程序崩溃、损坏和数据丢失。向非托管代码传递委托时,托管应用程序必须让这些委托保持活动状态,直到确信不会再次调用它们。

          如果不用成员变量,而用局部变量引用被new出来的委托,那么非托管代码可能刚开始的几次回调是OK的,但是接下来就会出现上面所说的异常,原因就在于GC将局部变量和局部变量引用的委托对象都销毁了,非托管代码再去访问那个函数指针时发现指针指向的地址已经无效。

 

解决例子

private LowLevelMouseProc _proc; 
private delegate IntPtr LowLevelMouseProc(int nCode, IntPtr wParam, IntPtr lParam); 
private IntPtr SetHook(LowLevelMouseProc proc) 
       { 
           using (Process curProcess = Process.GetCurrentProcess()) 
           using (ProcessModule curModule = curProcess.MainModule) 
           {

                _proc=HookCallback; 
                return SetWindowsHookEx(WH_MOUSE_LL, proc, 
                   GetModuleHandle(curModule.ModuleName), 0); 
           } 
       } 


 

Reference:

对“XXX::Invoke”类型的已垃圾回收委托进行了回调。这可能会导致应用程序崩溃、损坏和数据丢失。向非托管代码传递委托时,托管应用程序必须让这些委托保持活动状态,直到确信不会再次调用它们。

C#处理C++库回调报错_非托管代码传递委托被垃圾回收

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值