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
  • 相关阅读:
    Storm:分布式流式计算框架
    GreenPlum:基于PostgreSQL的分布式关系型数据库
    Hive和SparkSQL: 基于 Hadoop 的数据仓库工具
    Linux网络子系统
    Python标准模块--multiprocessing
    Python标准模块--built-ins函数
    Python标准模块--threading
    Python标准模块--import
    Python标准模块--os
    Python标准模块--argparse
  • 原文地址:https://www.cnblogs.com/zeroone/p/9894127.html
Copyright © 2011-2022 走看看