我还没有找到答案,我能够适应我的问题。
所以情况就是这样: 我需要测试12个网络摄像机的功能,所有这些都做同样的工作。 所以,我正在启动12个线程,连接到摄像头。
每个线程都在发送激活命令,然后等待10秒钟以获得响应,预计不会发生响应。
在这10秒之后,线程应进入等待状态并通知主线程。
一旦所有12个线程都处于等待状态,就会通过串行连接发送命令,线程应继续工作。现在他们应该得到答案。
到目前为止,我已经启动了12个线程,但我不知道如何在这一点上使它们同步。
任何帮助?
到目前为止代码:
Dictionary<String, Thread> tl = new Dictionary<String, Thread>();
Thread t;
foreach (String ip in this.ips) {
t = new Thread(new ParameterizedThreadStart(camWorker));
tl.Add(ip, t);
tl[ip].Start();
}
但如果需要,可以重建它以为每个线程创建单独的类实例。
答案 0 :(得分:2)
您可以使用重置事件。为每个线程创建一个重置事件,最后等待所有12个重置事件完成。
示例:
var resetEvents = new List<AutoResetEvent>();
for (int i = 0; i < 12; i++)
{
var re = new AutoResetEvent(false);
resetEvents.Add(re);
ThreadPool.QueueUserWorkItem(w =>
{
var threadReset = w as AutoResetEvent;
var random = new Random();
try
{
// do something.
Thread.Sleep(random.Next(100, 2000));
}
catch (Exception ex)
{
// make sure you catch exceptions and release the lock.
// otherwise you will get into deadlocks
}
// when ready:
Console.WriteLine("Done thread " + Thread.CurrentThread.ManagedThreadId);
threadReset.Set();
}, re);
}
// this bit will wait for all 12 threads to set
foreach (AutoResetEvent resetEvent in resetEvents)
{
resetEvent.WaitOne();
}
// At this point, all 12 of your threads have signaled that they're ready.
答案 1 :(得分:0)
bool[] timeout = new bool[12];
bool waitForSignal = true;
oneof12()
{
while(true)
{
if(receivedatabeforetimeout())
{
}
else
timeout[0] = true;
while(waitForSignal)
Thread.Sleep(500);
}
}
watcherThread()
{
bool allTimeout = true;
for(int a = 0; a<12;a++)
if(!timeout[0])
allTimeout = false;
if(allTimeout)
{
for(int a = 0; a<12;a++)
timeout[a] = false;
waitForSignal = false;
}
Thread.Sleep(200);
}
这样的事情会在你的情况下起作用吗?如果超时,12个线程中的每个线程都会将bool数组中的索引设置为true。观察者线程检查bool数组是否所有12都超时,如果有,它将waitForSignal标志设置为true,这导致12个线程退出while循环并再次等待数据
答案 2 :(得分:0)
这听起来像是一个很好的案例。基本上你可以等待12个任务,每个任务检查一个摄像机的状态。这样做的好处是您无需管理独立的线程。
using System.Linq;
using System.Threading.Tasks;
...
var Tasks = this.ips.Select(ip => Task.Run(() => Check(ip))).ToArray();
Task.WaitAll(Tasks);
//inspect Task.Result to display status and perform further work
请注意,您的Check
方法可以返回结果,然后可以通过Task.Result
访问该结果。 Task.WaitAll
阻止当前线程,直到所有任务都运行完毕。
目前尚不清楚您将这个代码称为什么,但如果合适,您也可以使用C#的async功能。
答案 3 :(得分:0)
我建议使用“任务”。
List<Task> tasks = new List<Task>();
for (int i=0; i<10; i++)
{
tasks.Add(Task.Factory.StartNew(() => DoSomething());
}
Task.WaitAll(tasks);
这将使所有任务在后台并行运行,并等待它们全部完成以继续。