public delegate void SendCallbackType();public class SenderBase{SenderBase(){mySend = new SendCallbackType(SendData);mySend.BeginInvoke(SendCallback, null);}void SendData(){ // process / ...

public delegate void SendCallbackType();
public class SenderBase
{
SenderBase()
{
mySend = new SendCallbackType(SendData);
mySend.BeginInvoke(SendCallback, null);
}
void SendData()
{
// process / sending data
}
void SendCallback(IAsyncResult ar)
{
**SendCallbackType worker = (SendCallbackType)((AsyncResult)ar).AsyncDelegate;
worker.EndInvoke(ar);**
//Above code is mandatory ? Working fine without them.
mySend.BeginInvoke(SendCallback, null);
}
// Test
Dictionary<SenderBase> SenderCollection = new Dictionary();
SenderCollection.Add(new SenderBase());
SenderCollection.Remove(0);
// Add and remove seven times
对象(SenderBase)不是垃圾收集的.他们不断向下一代移动.
使用RedAnts Memory Profiler,
任何清理对象的建议.
谢谢.
解决方法:
你一直在调用mySend.BeginInvoke().因此,垃圾收集器总是在线程池线程的堆栈上看到对mySend对象的引用.因此不会收集它.当然,代码一直在运行.
在这种情况下不调用EndInvoke()是一个坏主意,它为每个BeginInvoke()调用泄漏资源10分钟.默认的远程处理生命周期,远程处理是实现委托的BeginInvoke()方法的底层管道.
很难提出清理代码的建议,这样做没有多大意义.你也可以使用while(true){}循环启动一个线程.这肯定会更有效率.
织梦狗教程
本文标题为:c# – 具有回调的代理上的内存泄漏


基础教程推荐
猜你喜欢
- c# – USING块在网站与Windows窗体中的行为不同 2023-09-20
- C#通过标签软件Bartender的ZPL命令打印条码 2023-05-16
- C# 解析XML和反序列化的示例 2023-04-14
- Unity 如何获取鼠标停留位置下的物体 2023-04-10
- C#调用摄像头实现拍照功能的示例代码 2023-03-09
- Unity shader实现高斯模糊效果 2023-01-16
- C#中的Linq to JSON操作详解 2023-06-08
- 实例详解C#实现http不同方法的请求 2022-12-26
- C#中 Json 序列化去掉null值的方法 2022-11-18
- C#获取指定目录下某种格式文件集并备份到指定文件夹 2023-05-30