
代码是这样的:
List<Data> List = null; try { locker.EnterReadLock(); List = internalData[Something].Where(x => x.hassomething()).ToList(); } finally { locker.ExitReadLock(); } foreach (var y in List) { result[y.proprty1].Add(y.property2); // <-- here it hangs } return result; 所以internalData用readerwriterlockslim锁定所有 *** 作,readerlock用于读取,writerlock用于添加.我复制了锁内的项目,稍后再处理这个副本.
问题是过了一段时间,越来越多的cpu核心达到100%,最后使用所有核心.它可以在停止前完美运行数天和数百万次通话.
附加调试器和暂停显示添加到结果字典时会出现一个问题.但是一旦我恢复,所有线程都将继续,并且正在释放大量内存.
附加调试器时会发生什么特别的事情,暂停和恢复会释放这样的东西吗?
解决方法 我把锁更改为锁定(某些){code …}并且挂起的问题消失了.所以看起来lilke我遇到了Steffen Winkler在他的评论中指出的问题. http://joeduffyblog.com/2007/02/07/introducing-the-new-readerwriterlockslim-in-orcas/ 总结以上是内存溢出为你收集整理的c# – 线程挂起,直到我附加调试器全部内容,希望文章能够帮你解决c# – 线程挂起,直到我附加调试器所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)