sch*_*opy 6 c# io multithreading
我构建了一个应用程序,可以对数千个文件执行操作,然后将这些文件的修改后的副本写入磁盘.我正在使用ThreadPool,但它产生了如此多的线程,因为PC总共没有响应260,所以我将默认值250的最大值更改为50,这解决了这个问题(应用程序仅产生约60个线程),但是现在文件正在变得如此快速地准备好,它将UI绑定到电脑没有响应的程度.
有没有办法限制I/O的数量 - 我的意思是,我喜欢使用50个线程来执行文件的工作,但不是50个线程在处理它们的同时写入.如果我可以保留它,我宁愿不重新构建文件部分的编写 - 我希望我可以限制来自此池的线程可以消耗的I/O(同时)量.
使用信号量来限制否.想要同时写入磁盘的线程
http://msdn.microsoft.com/en-us/library/system.threading.semaphore.aspx
限制可以同时访问资源或资源池的线程数.
| 归档时间: | 
 | 
| 查看次数: | 550 次 | 
| 最近记录: |