zoukankan      html  css  js  c++  java
  • Multiple Tasks Z

    public static async Task executeParallel<T>(this IEnumerable<T> items, int limit, Func<T, Task> actionMethod)
            {
                var allTasks = new List<Task>(); //Store all Tasks
                var activeTasks = new List<Task>();
                foreach (var item in items)
                {
                    if (activeTasks.Count >= limit)
                    {
                        var completedTask = await Task.WhenAny(activeTasks);
                        activeTasks.Remove(completedTask);
                    }
                    var task = actionMethod(item);
                    allTasks.Add(task);
                    activeTasks.Add(task);
                }
                await Task.WhenAll(allTasks); // Wait for all task to complete
            }

    public async Task fun(int processId)
           {
               await Task.Run( () =>{
                   Random rand = new Random();
                   Console.WriteLine("Processing " + processId);
                   Thread.Sleep(rand.Next(1500));
                   Console.WriteLine("Done processing - " + processId);
               });
           }

      internal async void process(List<int> queue,int limit)
            {
                await queue.executeParallel(limit, fun);
            }



    https://www.codeproject.com/Tips/1264928/Throttling-Multiple-Tasks-to-Process-Requests-in-C
  • 相关阅读:
    C#继承
    正则表达式
    C#笔记
    斐波那契数
    out参数
    重载和重写
    数组元素交换位置
    Win10图标显示不正常解决办法
    Linux添加sftp用户并限制其访问目录
    pclzip 解压的文件去掉文件夹
  • 原文地址:https://www.cnblogs.com/zeroone/p/9894127.html
Copyright © 2011-2022 走看看