1

我正在创建一个包含 5 个任务的数组,调用字符串返回方法“Essen”

        tasks[0] = new Task(() => Philosoph.Essen("1", gabeln[2], gabeln[1]));
        tasks[1] = new Task(() => Philosoph.Essen("2", gabeln[3], gabeln[2]));
        tasks[2] = new Task(() => Philosoph.Essen("3", gabeln[4], gabeln[3]));
        tasks[3] = new Task(() => Philosoph.Essen("4", gabeln[5], gabeln[4]));
        tasks[4] = new Task(() => Philosoph.Essen("5", gabeln[1], gabeln[5]));

然后我使用 Parallel.ForEach 开始这些任务

       Parallel.ForEach(tasks, t =>
        {

            t.Start();
        });
        Task.WaitAll(tasks); 

方法 Essen 正在返回字符串

    static public string Essen(String philosoph, String linkeGabel, String rechteGabel)
    {
        lock (linkeGabel)
        {
            lock (rechteGabel)
            {
               return ("Philosoph " + philosoph + "isst mit: " + linkeGabel + ", " + rechteGabel );
            }
        }
    }

如何在 5 个并行处理中的每一个处理 Essen()-Return 值?我想将这些返回值写入列表框...

4

1 回答 1

2

您使用ContinueWhenAll

// once tasks are started
TaskFactory.ContinueWhenAll(
    tasks,
    results =>
    {
        foreach (var t in results)
        {
            if (t.IsCompleted)
                listBox.Items.Add(t.Result);
        }
    },
    cts.Token,
    TaskContinuationOptions.None,
    TaskScheduler.FromCurrentSynchronizationContext());

请务必为您的ListBox. 此外,您需要确保您“观察”任何Task<TResult>.Exception可能发生的事情(即如果t.IsFaultedcheck out t.Exception)。

但是,目前您的任务未定义为返回任何内容。您需要将它们的定义更改为Task<TResult>

// will use the return type of Philosoph.Essen, which is string
// Task<string>[] tasks;
var tasks = new []
{
    Task.Factory.StartNew(() => Philosoph.Essen("1", gabeln[2], gabeln[1])),
    Task.Factory.StartNew(() => Philosoph.Essen("2", gabeln[3], gabeln[2])),
    Task.Factory.StartNew(() => Philosoph.Essen("3", gabeln[4], gabeln[3])),
    Task.Factory.StartNew(() => Philosoph.Essen("4", gabeln[5], gabeln[4])),
    Task.Factory.StartNew(() => Philosoph.Essen("5", gabeln[1], gabeln[5])),
};
于 2013-06-05T16:56:09.383 回答