我构建了一个应用程序,可以对数千个文件执行操作,然后将这些文件的修改后的副本写入磁盘.我正在使用ThreadPool,但它产生了如此多的线程,因为PC总共没有响应260,所以我将默认值250的最大值更改为50,这解决了这个问题(应用程序仅产生约60个线程),但是现在文件正在变得如此快速地准备好,它将UI绑定到电脑没有响应的程度.
有没有办法限制I / O的数量 – 我的意思是,我喜欢使用50个线程来执行文件的工作,但不是50个线程在处理它们的同时写入.如果我可以保留它,我宁愿不重新构建文件部分的编写 – 我希望我可以限制来自此池的线程可以消耗的I / O(同时)量.
解决方法
使用信号量来限制否.想要同时写入磁盘的线程
http://msdn.microsoft.com/en-us/library/system.threading.semaphore.aspx
Limits the number of threads that can access a resource or pool of resources concurrently.