gpt4 book ai didi

c# - 将数据从多个线程发送回主线程的最佳方法是什么?

转载 作者:太空宇宙 更新时间:2023-11-03 18:38:08 25 4
gpt4 key购买 nike

我有一个主线程,我确实创建了另一个 n 线程。 n 个线程中的每一个都在填充 List<String> .当所有线程都完成后,它们就会连接起来,我想将所有这些 n 线程列表放在 List<List<String>> 中。但是在主线程中。主线程应该能够在 List<List<String>> 上运行. n 个线程中的每一个都贡献了一个 List<String> .

我有 c# .NET 3.5,我想避免 static List<List<String>>

            Thread t = new Thread(someObjectForThreading.goPopulateList);
list_threads.Add(t);
list_threads.last().start()

list_threads 中的所有这些线程继续并填充它们的列表,当它们完成时我想要类似的东西

 //this = mainThread
this.doSomethingWith(List<List<String>>)

编辑:嗯,有没有一个“标准概念”来解决这样的任务?许多线程在列表上操作,当所有线程都加入时,主线程可以继续在列表上操作。

Edit2:List<List<String>> listOfLists不能是静态的。 可以是 public or private .首先,我需要 n 个线程来操作(并锁定)listOfLists,插入它们的列表,在所有 n 个线程完成插入它们的列表之后,我将加入线程,主线程可以继续处理业务逻辑并在 listOfLists 上操作。

我想我会重新阅读 http://www.albahari.com/threading/ 的某些部分返回

最佳答案

这是一个简单的实现,它使用等待句柄(在 ManualResetEvent 的例子中)允许每个工作线程向主线程发出它已完成工作的信号。我希望这是不言自明的:

private List<List<string>> _listOfLists;

public void CreateListOfLists()
{
var waitHandles = new List<WaitHandle>();

foreach (int count in Enumerable.Range(1, 5))
{
var t = new Thread(CreateListOfStringWorker);
var handle = new ManualResetEvent(false);
t.Start(handle);
waitHandles.Add(handle);
}

// wait for all threads to complete by calling Set()
WaitHandle.WaitAll(waitHandles.ToArray());

// do something with _listOfLists
// ...
}

public void CreateListOfStringWorker(object state)
{
var list = new List<string>();
lock (_listOfLists)
{
_listOfLists.Add(list);
}

list.Add("foo");
list.Add("bar");

((ManualResetEvent) state).Set(); // i'm done
}

请注意我是如何仅在将每个线程的列表添加到列表的主列表时才进行锁定的。无需为每次添加锁定主列表,因为每个线程都有自己的列表。有道理吗?

编辑:

使用 waithandle 的要点是在处理列表列表之前等待每个线程完成。如果您不等待,那么当工作人员仍在向其中添加字符串时,您将面临尝试枚举其中一个 List 实例的风险。这将导致抛出 InvalidOperationException,您的线程将终止。您不能在枚举集合的同时修改它。

关于c# - 将数据从多个线程发送回主线程的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12205528/

25 4 0