ann*_*lie 8 c# multithreading .net-3.5
我是线程新手,想做类似这个问题的事情:
但是,我不确定这个解决方案是否对我来说是最好的,因为我希望它们继续运行并且永远不会完成.(对于那个问题,我也使用.net 3.5而不是2.0.)
我想做这样的事情:
foreach (Agent agent in AgentList)
{
// I want to start a new thread for each of these
agent.DoProcessLoop();
}
---
public void DoProcessLoop()
{
while (true)
{
// do the processing
// this is things like check folder for new files, update database
// if new files found
}
}
Run Code Online (Sandbox Code Playgroud)
ThreadPool是最好的解决方案还是有更适合这种情况的东西?
更新:感谢所有的好答案!我以为我会更详细地解释用例.许多代理可以将文件上载到文件夹.每个代理都有自己的文件夹,可以将资源上传到(csv文件,图像,pdf).我们的服务(它意味着是在他们上传资产的服务器上运行的Windows服务,请放心,我将很快回来关于Windows服务的问题:))如果有任何新资产,将继续检查每个代理的文件夹,如果有,数据库将被更新,并为其中一些创建静态html页面.因为他们可能需要一段时间来上传所有内容,我们希望他们能够立即看到他们上传的更改,我们认为每个代理的线程都是个好主意,因为没有代理人需要等待其他人来完成(我们有多个处理器,所以想要使用它们的全部容量).希望这能解释它!
谢谢,
Annelie
Rag*_*czy 12
鉴于您描述的特定用法(正在查看文件),我建议您使用FileSystemWatcher 来确定何时有新文件,然后使用线程池触发线程来处理文件,直到没有更多要处理的文件为止 -哪个线程退出.
这应该减少i/o(因为你不是经常轮询磁盘),减少CPU使用率(因为轮询磁盘的多个线程的常量循环将使用循环),并减少你在任何时候运行的线程数(假设没有对文件系统进行不断的修改).
您可能只想在主线程上打开和读取文件,并将数据传递给工作线程(如果可能),以将i/o限制为单个线程.
我相信Parallels Extensions使这成为可能:
Parallel.Foreach
Run Code Online (Sandbox Code Playgroud)
http://msdn.microsoft.com/en-us/library/system.threading.tasks.parallel.foreach.aspx http://blogs.msdn.com/pfxteam/
| 归档时间: |
|
| 查看次数: |
1835 次 |
| 最近记录: |