在同一时间执行相同的多任务

本文关键字:多任务 同一时间 执行 | 更新日期: 2023-09-27 17:55:45

我在 Asp.net C# 中遇到问题

我有下面的代码: 列表对象列表 = 新列表();

foreach(var item in listItem)
{
  object obj = getData (item);
  objectList.add(obj);
}
Console.Write("Finish all");

每次"获取数据(项目);"触发大约需要 1 秒;

我希望listItem中的所有项目同时运行,然后在foreach完成Console.write("Finish all")后执行

我该怎么做?

任何想法将不胜感激!

在同一时间执行相同的多任务

您可以尝试 Parallel.Foreach.其中每个迭代可以并行运行。

您可以使用

Task来完成它:

 var tasks = listItem.Select(item => Task.Factory.StartNew(() => aaa()));
 Task.WaitAll(tasks.ToArray());
 Console.Write();

如果您不需要等待所有任务完成,只需跳过WaitAll

 var tasks = listItem.Select(item => Task.Factory.StartNew(() => aaa()));
 Console.Write();

对于 .NET 3.5,可以使用 ThreadPool:

 listItem.ForEach(item => ThreadPool.QueueUserWorkItem(state => aaa()));
 Console.Write();
 using System.Threading;
 using System.Threading.Tasks;
 List<Task> tasks = new List<Task>();
 foreach(item in listItem)
 {
       tasks.Add(Task.Factory.StartNew(() => aaa()));
 }
// If you want the Console.Writeline to execute immediately after starting the tasks
Console.Writeline();            
Task.WaitAll(tasks.ToArray());
Console.Writeline("Finised executing all tasks");


如果你想使用线程来做到这一点,你可以:
List<ManualResetEvent> resetEvents = new List<ManualResetEvent>();
.
.
.

 foreach(item in lisItem)
            {
                Thread thread = new Thread(new ParameterizedThreadStart(aaa));
                ManualResetEvent resetEvent = new ManualResetEvent(false);
                resetEvents.Add(resetEvent);
                thread.Start(resetEvent);
            }
            Console.WriteLine();
            WaitHandle.WaitAll(resetEvents.ToArray<WaitHandle>());
            Console.WriteLine("Finised executing all threads");

        }
}
.
.
.
    void aaa(object data)
    {
        ManualResetEvent resetEvent = data as ManualResetEvent;
        // completed execution
        Console.WriteLine(".");
        resetEvent.Set();
    }
        int itemCount = ItemList.Count;
             List<object> objectList = new List<object>();
            ManualResetEvent[] resetEvents = new ManualResetEvent[itemCount];
            for (int i = 0; i < itemCount; i++)
            {
                var item= ItemList[i];
                resetEvents[i] = new ManualResetEvent(false);
                ThreadPool.QueueUserWorkItem(new WaitCallback((object index) =>
                {
                    ItemCalEvent item = getData(item);
                    lock (objectList)
                        objectList.Add(item);
                    resetEvents[(int)index].Set();
                }), i);
            }
            WaitHandle.WaitAll(resetEvents);

这在 .net 3.5 中很好