C# 将每个列表项逐个传递给新线程
我想做的很简单,C# 将每个列表项逐个传递给新线程,c#,multithreading,synchronization,C#,Multithreading,Synchronization,我想做的很简单, 我扫描一个字符串列表,然后将每个字符串传递给一个新线程进行打印 using System; using System.Collections.Generic; using System.Threading; namespace MultithreadingSynchronization { class Program { static void Main(string[] args) { List<
我扫描一个字符串列表,然后将每个字符串传递给一个新线程进行打印
using System;
using System.Collections.Generic;
using System.Threading;
namespace MultithreadingSynchronization
{
class Program
{
static void Main(string[] args)
{
List<string> stringList = new List<string> { "server1", "server2", "server3", "server4", "server5", "server6", "server7", "server8", "server9"};
foreach (string server in stringList)
{
ThreadStart work = delegate { Threadjob(server); };
new Thread(work).Start();
//Thread.Sleep(10); // 10 ms delay of main thread
}
}
public static void Threadjob(object server)
{
Console.WriteLine(server);
}
}
}
但是,有时我会这样:
server3
server2
server5
server5
server7
server4
server8
server9
server9
server2
server2
server4
server3
server6
server7
server7
server8
server9
有时我会这样:
server3
server2
server5
server5
server7
server4
server8
server9
server9
server2
server2
server4
server3
server6
server7
server7
server8
server9
等等
事实上,如果我在每个线程创建之后都延迟一段时间,我就得到了我期望得到的结果
有什么想法吗?您应该制作变量的本地副本。 试试这个:
foreach (string server in stringList)
{
string local = server;
ThreadStart work = delegate { Threadjob(local); };
new Thread(work).Start();
//Thread.Sleep(10); // 10 ms delay of main thread
}
更多信息请点击此处:
完成了!但是,使用任务而不是线程可能更明智,或者至少使用线程池。好的,我想我明白了
Froeach循环持有一个指针,并在每次迭代中更改它。 有时,线程被创建,但仍然没有运行。 同时,循环在下一次迭代中更改指针,当线程开始其作业时,它将获得当前指针的值(后续字符串) 顺便说一句,我找到了另一个解决方案,如何将参数传递给线程的主函数,所以我修复了我的循环,现在它可以正常工作了
foreach (string server in stringList)
{
Thread thread1 = new Thread(new ParameterizedThreadStart(Threadjob));
thread1.Start(server);
}
我试过你的代码(vs2012 C#控制台应用默认设置,win8.0 64)-我从来没有重复过数字。-我确实让它们出了问题,正如您对多线程的期望,但不是重复。您不希望您的ThreadJob方法成为实例方法吗?它似乎不是线程安全的,这是因为循环变量。按照oakio的建议,更改为for循环或使用本地foreach变量。@WarpWars.Net,我使用的是VS2010(在Win 7上),这可能是区别吗?@elady是的:这种行为在c#5中是固定的,因为它让太多人困惑了如果你发现一个重复的问题,你应该投票/标记以重复的形式关闭它,而不是张贴答案。非常感谢!它解决了我的问题!这也解决了我的问题,谢谢!