国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

winform開發使用通用多線程基類分享(以隊列形式)

2020-01-24 02:59:08
字體:
來源:轉載
供稿:網友

 

復制代碼 代碼如下:

/// <summary>
    /// 隊列多線程,T 代表處理的單個類型~
    /// </summary>
    /// <typeparam name="T"></typeparam>
    public abstract class QueueThreadBase<T>
    {
        #region 變量&屬性
        /// <summary>
        /// 待處理結果
        /// </summary>
        private class PendingResult
        {
            /// <summary>
            /// 待處理值
            /// </summary>
            public T PendingValue { get; set; }
            /// <summary>
            /// 是否有值
            /// </summary>
            public bool IsHad { get; set; }
        }
        /// <summary>
        /// 線程數
        /// </summary>
        public int ThreadCount
        {
            get { return this.m_ThreadCount; }
            set { this.m_ThreadCount = value; }
        }
        private int m_ThreadCount = 5;
        /// <summary>
        /// 取消=True
        /// </summary>
        public bool Cancel { get; set; }
        /// <summary>
        /// 線程列表
        /// </summary>
        List<Thread> m_ThreadList;
        /// <summary>
        /// 完成隊列個數
        /// </summary>
        private volatile int m_CompletedCount = 0;
        /// <summary>
        /// 隊列總數
        /// </summary>
        private int m_QueueCount = 0;
        /// <summary>
        /// 全部完成鎖
        /// </summary>
        private object m_AllCompletedLock = new object();
        /// <summary>
        /// 完成的線程數
        /// </summary>
        private int m_CompetedCount = 0;
        /// <summary>
        /// 隊列鎖
        /// </summary>
        private object m_PendingQueueLock = new object();
        private Queue<T> m_InnerQueue;
        #endregion


        #region 事件相關
        /// <summary>
        /// 全部完成事件
        /// </summary>
        public event Action<CompetedEventArgs> AllCompleted;
        /// <summary>
        /// 單個完成事件
        /// </summary>
        public event Action<T, CompetedEventArgs> OneCompleted;
        /// <summary>
        /// 引發全部完成事件
        /// </summary>
        /// <param name="args"></param>
        private void OnAllCompleted(CompetedEventArgs args)
        {
            if (AllCompleted != null)
            {
                try
                {
                    AllCompleted(args);//全部完成事件
                }
                catch { }
            }
        }
        /// <summary>
        /// 引發單個完成事件
        /// </summary>
        /// <param name="pendingValue"></param>
        /// <param name="args"></param>
        private void OnOneCompleted(T pendingValue, CompetedEventArgs args)
        {
            if (OneCompleted != null)
            {
                try
                {
                    OneCompleted(pendingValue, args);
                }
                catch { }

            }
        }
        #endregion

        #region 構造
        public QueueThreadBase(IEnumerable<T> collection)
        {
            m_InnerQueue = new Queue<T>(collection);
            this.m_QueueCount = m_InnerQueue.Count;
        }

        #endregion

        #region 主體
        /// <summary>
        /// 初始化線程
        /// </summary>
        private void InitThread()
        {
            m_ThreadList = new List<Thread>();
            for (int i = 0; i < ThreadCount; i++)
            {
                Thread t = new Thread(new ThreadStart(InnerDoWork));
        m_ThreadList.Add(t);
                t.IsBackground = true;
                t.Start();
            }
        }
        /// <summary>
        /// 開始
        /// </summary>
        public void Start()
        {
            InitThread();
        }
        /// <summary>
        /// 線程工作
        /// </summary>
        private void InnerDoWork()
        {
            try
            {
                Exception doWorkEx = null;
                DoWorkResult doworkResult = DoWorkResult.ContinueThread;
                var t = CurrentPendingQueue;
                while (!this.Cancel && t.IsHad)
                {
                    try
                    {
                        doworkResult = DoWork(t.PendingValue);
                    }
                    catch (Exception ex)
                    {
                        doWorkEx = ex;
                    }
                    m_CompletedCount++;
                    int precent = m_CompletedCount * 100 / m_QueueCount;
                    OnOneCompleted(t.PendingValue, new CompetedEventArgs() { CompetedPrecent = precent, InnerException = doWorkEx });
                    if (doworkResult == DoWorkResult.AbortAllThread)
                    {
                        this.Cancel = true;
                        break;
                    }
                    else if (doworkResult == DoWorkResult.AbortCurrentThread)
                    {
                        break;
                    }
                    t = CurrentPendingQueue;
                }

                lock (m_AllCompletedLock)
                {
                    m_CompetedCount++;
                    if (m_CompetedCount == m_ThreadList.Count)
                    {
                        OnAllCompleted(new CompetedEventArgs() { CompetedPrecent = 100 });
                    }
                }

            }
            catch
            {
                throw;
            }
        }
        /// <summary>
        /// 子類重寫
        /// </summary>
        /// <param name="pendingValue"></param>
        /// <returns></returns>
        protected virtual DoWorkResult DoWork(T pendingValue)
        {
            return DoWorkResult.ContinueThread;
        }
        /// <summary>
        /// 獲取當前結果
        /// </summary>
        private PendingResult CurrentPendingQueue
        {
            get
            {
                lock (m_PendingQueueLock)
                {
                    PendingResult t = new PendingResult();
                    if (m_InnerQueue.Count != 0)
                    {
                        t.PendingValue = m_InnerQueue.Dequeue();
                        t.IsHad = true;
                    }
                    else
                    {
                        t.PendingValue = default(T);
                        t.IsHad = false;
                    }
                    return t;
                }
            }
        }

        #endregion

        #region 相關類&枚舉
        /// <summary>
        /// dowork結果枚舉
        /// </summary>
        public enum DoWorkResult
        {
            /// <summary>
            /// 繼續運行,默認
            /// </summary>
            ContinueThread = 0,
            /// <summary>
            /// 終止當前線程
            /// </summary>
            AbortCurrentThread = 1,
            /// <summary>
            /// 終止全部線程
            /// </summary>
            AbortAllThread = 2
        }
        /// <summary>
        /// 完成事件數據
        /// </summary>
        public class CompetedEventArgs : EventArgs
        {
            public CompetedEventArgs()
            {

            }
            /// <summary>
            /// 完成百分率
            /// </summary>
            public int CompetedPrecent { get; set; }
            /// <summary>
            /// 異常信息
            /// </summary>
            public Exception InnerException { get; set; }
        }
        #endregion

    }

1.從構造函數來看,處理的是一個確定的列表.沒錯.這個多線程只能處理已經確定的列表,你是否會問.可不可以一邊添加,一邊處理呢?(呵呵,可以,請聯系樓主,當然你也可以自己寫,是吧?!)

復制代碼 代碼如下:

public QueueThreadBase(IEnumerable<T> collection)

2.提供撤銷的功能

復制代碼 代碼如下:

/// <summary>
        /// 取消=True
        /// </summary>
        public bool Cancel { get; set; }

3.提供線程個數修改功能

復制代碼 代碼如下:

/// <summary>
        /// 線程數
        /// </summary>
        public int ThreadCount
        {
            get { return this.m_ThreadCount; }
            set { this.m_ThreadCount = value; }
        }

4.提供多種事件響應,如單個完成,全部完成的事件

復制代碼 代碼如下:

/// <summary>
        /// 全部完成事件
        /// </summary>
        public event Action<CompetedEventArgs> AllCompleted;
        /// <summary>
        /// 單個完成事件
        /// </summary>
        public event Action<T, CompetedEventArgs> OneCompleted;

5.提供完成的百分率

復制代碼 代碼如下:

/// <summary>
        /// 完成事件數據
        /// </summary>
        public class CompetedEventArgs : EventArgs
        {
            public CompetedEventArgs()
            {

            }
            /// <summary>
            /// 完成百分率
            /// </summary>
            public int CompetedPrecent { get; set; }
            /// <summary>
            /// 異常信息
            /// </summary>
            public Exception InnerException { get; set; }
        }

6.提供終止線程的方式,繼續/單線程終止/全部終止

復制代碼 代碼如下:

/// <summary>
        /// dowork結果枚舉
        /// </summary>
        public enum DoWorkResult
        {
            /// <summary>
            /// 繼續運行,默認
            /// </summary>
            ContinueThread = 0,
            /// <summary>
            /// 終止當前線程
            /// </summary>
            AbortCurrentThread = 1,
            /// <summary>
            /// 終止全部線程
            /// </summary>
            AbortAllThread = 2
        }

你是否會問?怎么用呢?別急....請看

復制代碼 代碼如下:

/// <summary>
    /// 下載線程對了.
    /// </summary>
    public class DownLoadQueueThread:QueueThreadBase<int>
    {
        /// <summary>
        ///
        /// </summary>
        /// <param name="list">下載的列表ID</param>
        public DownLoadQueueThread(IEnumerable<int> list):base(list)
        {

        }
        /// <summary>
        /// 每次多線程都到這里來,處理多線程
        /// </summary>
        /// <param name="pendingValue"列表ID></param>
        /// <returns></returns>
        protected override DoWorkResult DoWork(int pendingID)
        {
            try
            {

                //..........多線程處理....
                return DoWorkResult.ContinueThread;//沒有異常讓線程繼續跑..

            }
            catch (Exception)
            {

                return DoWorkResult.AbortCurrentThread;//有異常,可以終止當前線程.當然.也可以繼續,
                //return  DoWorkResult.AbortAllThread; //特殊情況下 ,有異常終止所有的線程...
            }

            //return base.DoWork(pendingValue);
        }
    }

用法

總結:

多線程在什么時候都會用到.不用到是你不會用.多線程要一定的編程基礎,如果你覺得有點難度,那你可以學習并且借鑒人家已有的東西.少走彎路,是我們程序員經歷嗷嗷待哺后的心聲.本文以交流態度和感恩心態,貢獻給有需要的人們.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 彭泽县| 班玛县| 南漳县| 昌宁县| 孝义市| 双城市| 平原县| 佳木斯市| 东光县| 惠东县| 文化| 阳城县| 邵阳县| 百色市| 津南区| 安达市| 迁西县| 汉源县| 株洲市| 郎溪县| 怀安县| 宜丰县| 中西区| 武宁县| 容城县| 克东县| 迭部县| 江孜县| 呼和浩特市| 鄂托克旗| 湖口县| 谷城县| 始兴县| 吉安县| 东海县| 庆阳市| 崇信县| 开封市| 绵竹市| 永善县| 安顺市|