• 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
  • 相关阅读:
    LeetCode 141. Linked List Cycle(判断链表是否有环)
    LeetCode 680. Valid Palindrome II(双指针)
    >/dev/null 2>&1
    18个最佳代码编辑器
    vi和vim常用命令
    搞定Windows连Linux三大件:SecureCRT,FileZilla,NX
    define和typedef的区别
    C++ const,static成员
    C++虚函数练习题
    c++虚函数解析
  • 原文地址:https://www.cnblogs.com/zeroone/p/9894127.html
Copyright © 2020-2023  润新知