gpt4 book ai didi

C#多线程文件IO(阅读)

转载 作者:行者123 更新时间:2023-11-30 13:21:06 28 4
gpt4 key购买 nike

我们有这样一种情况,我们的应用程序需要处理一系列文件,而不是同步执行此功能,我们希望采用多线程将工作负载分配给不同的线程。

每一项工作是:
1.以只读方式打开文件
2.处理文件中的数据
3.将处理后的数据写入Dictionary

我们想在一个新线程上执行每个文件的工作?这是否可能,我们是否应该更好地使用 ThreadPool 或生成新线程,记住每个“工作”项目只需要 30 毫秒,但是可能需要处理数百个文件。

如果有任何提高效率的想法,我们将不胜感激。

编辑:目前我们正在使用 ThreadPool 来处理这个问题。如果我们有 500 个文件要处理,我们循环处理这些文件并使用 QueueUserWorkItem 将每个“处理工作单元”分配给线程池。

为此使用线程池是否合适?

最佳答案

我建议您使用ThreadPool.QueueUserWorkItem(...),在这种情况下,线程由系统和.net 框架管理。您与自己的线程池融合的机会要高得多。所以我建议你使用 .net 提供的线程池。非常容易使用,

ThreadPool.QueueUserWorkItem(new WaitCallback(YourMethod), ParameterToBeUsedByMethod); 

你的方法(对象 o){
你的代码在这里...

如需更多阅读,请点击链接 http://msdn.microsoft.com/en-us/library/3dasc8as%28VS.80%29.aspx

希望对你有帮助

关于C#多线程文件IO(阅读),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2673448/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com