zoukankan      html  css  js  c++  java
  • 多任务管理类 MutilTaskManager

    计算和计算所需的数据能被较为平均的非配到若干task的时候,下面的任务管理类可以提供在大数据大计算量的情况下非精确的控制task的执行数量来限制计算量和内存占用量.

    下面是代码(非线程安全版本):

        public class MutilTaskManager
        {
            private readonly int _maxRun;
            private readonly int _maxQuenen;
            private List<Task> _taskRunningList;
            private readonly Queue<Task> _taskQueue;

            public bool IsQueueFull
            {
                get { return _taskQueue.Count > _maxQuenen; }
            }

            public MutilTaskManager(int maxRun = 8int maxQuenen = 2)
            {
                _maxRun = maxRun;
                _maxQuenen = maxQuenen;
                _taskRunningList = new List<Task>(maxRun);
                _taskQueue = new Queue<Task>(2);
            }

            public void TakeBooting(int sleepTime = 10)
            {
                if (_taskRunningList.Count >= _maxRun)
                {
                    _taskRunningList = _taskRunningList.Where(it => !it.IsCompleted).ToList();
                }
                while (_taskRunningList.Count < _maxRun && _taskQueue.Count > 0)
                {
                    var t = _taskQueue.Dequeue();
                    _taskRunningList.Add(t);
                    t.Start();
                }
                System.Threading.Thread.Sleep(sleepTime);
            }

            public void Enqueue(Task task)
            {
                _taskQueue.Enqueue(task);
                TakeBooting(0);
            }

            public void WaitAll()
            {
                while (_taskQueue.Count > 0)
                {
                    TakeBooting();
                }
                Task.WaitAll(_taskRunningList.ToArray());
            }
        }

    线程安全版本:

    public class MutilTaskManager
        {
            private readonly int _maxRun;
            private readonly int _maxQuenen;
            private List<Task> _taskRunningList;
            private readonly Queue<Task> _taskQueue;
            private object _lockObj = new object();
            public bool IsQueueFull
            {
                get { return _taskQueue.Count > _maxQuenen; }
            }

            public MutilTaskManager(int maxRun = 8int maxQuenen = 2)
            {
                _maxRun = maxRun;
                _maxQuenen = maxQuenen;
                _taskRunningList = new List<Task>(maxRun);
                _taskQueue = new Queue<Task>(2);
            }

            public void TakeBooting(int sleepTime = 10)
            {
                lock (_lockObj)
                {
                    if (_taskRunningList.Count >= _maxRun)
                    {
                        _taskRunningList = _taskRunningList.Where(it => !it.IsCompleted).ToList();
                    }
                    while (_taskRunningList.Count < _maxRun && _taskQueue.Count > 0)
                    {
                        var t = _taskQueue.Dequeue();
                        _taskRunningList.Add(t);
                        t.Start();
                    }
                }
                System.Threading.Thread.Sleep(sleepTime);
            }

            public void Enqueue(Task task)
            {
                lock (_lockObj)
                {
                    _taskQueue.Enqueue(task);
                }
                TakeBooting(0);
            }

            public void WaitAll()
            {
                while (_taskQueue.Count > 0)
                {
                    TakeBooting();
                }
                Task.WaitAll(_taskRunningList.ToArray());
            }
        }

    使用示例:

            void Test()
            {
                var mtm = new MutilTaskManager();
                foreach(int i in(new int[10]))
                {
                    while (mtm.IsQueueFull)
                    {
                        mtm.TakeBooting();
                    }
                    mtm.Enqueue(new Task(myTask));
                }
            }

            void myTask()
            {
                //read data
                
    //do something
            }
  • 相关阅读:
    Baum Welch估计HMM参数实例
    SVM 为什么要从原始问题变为对偶问题来求解
    Baum-Welch算法(EM算法)对HMM模型的训练
    LR采用的Sigmoid函数与最大熵(ME) 的关系
    01背包的常数优化的一点解释
    训练中文词向量
    TensorFlow L2正则化
    TensorFlow batch normalize的使用
    听说你的模型损失是NaN
    编译TensorFlow CPU指令集优化版
  • 原文地址:https://www.cnblogs.com/jinzhao/p/2410191.html
Copyright © 2011-2022 走看看