a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > 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);
        }
    }

用法

總結:

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产成人精品一区二区三区四区 | 91在线免费看 | 在线精品一区 | 超碰五月 | 国产精品免费视频观看 | 亚洲性在线观看 | 国产久| 男女视频在线 | 夜夜骑天天操 | 四虎新网站| 中文字幕亚洲欧美精品一区四区 | 黄色av免费观看 | 日韩视频二区 | 2020亚洲视频 | 一级片av | 久久国产亚洲精品 | 在线中文字幕av | 99视频免费 | 亚洲视频在线看 | 欧美日韩一区在线 | 日本高清h色视频在线观看 欧美成人精品一区二区三区 | 一区二区三区视频在线播放 | 亚洲欧洲av在线 | 亚洲福利在线播放 | 日韩欧美理论片 | 成人免费视频网站在线看 | 免费v片 | 一区综合| 免费黄色激情视频 | 一区二区日韩精品 | 国产在线视频一区二区 | 精品不卡 | 一区网站 | 在线色网站 | 91免费在线看 | 久草网站 | 欧美在线二区 | 免费国产羞羞网站视频 | 精品视频在线观看一区二区 | 不卡视频一区二区 | 亚洲精品第一页 |