我有一个使用WCF的服务.在内部,它有一个包含列表的字典,您可以添加或从不同的端点获取子集.
代码是这样的:
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/
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。