zoukankan      html  css  js  c++  java
  • C# -- 使用线程池 ThreadPool 执行多线程任务

    C# -- 使用线程池 ThreadPool 执行多线程任务

    1. 使用线程池

        class Program
        {
            static void Main(string[] args)
            {
                WaitCallback wc1 = s =>{
                    Console.WriteLine("线程ID:{0},开始执行", Thread.CurrentThread.ManagedThreadId);
                    Stopwatch stw = new Stopwatch();
                    stw.Start();
                    long result = SumNumbers(10000000);
                    stw.Stop();
                    Console.WriteLine("线程ID:{0},执行完成,执行结果:{1},执行用时{2},",Thread.CurrentThread.ManagedThreadId,result,stw.ElapsedMilliseconds);
                };
                WaitCallback wc2 = s => {
                    Console.WriteLine("线程ID:{0},开始执行", Thread.CurrentThread.ManagedThreadId);
                    Stopwatch stw = new Stopwatch();
                    stw.Start();
                    long result = SumNumbers(10000000);
                    stw.Stop();
                    Console.WriteLine("线程ID:{0},执行完成,执行结果:{1},执行用时{2},", Thread.CurrentThread.ManagedThreadId, result, stw.ElapsedMilliseconds);
                };
                WaitCallback wc3 = s => {
                    Console.WriteLine("线程ID:{0},开始执行", Thread.CurrentThread.ManagedThreadId);
                    Stopwatch stw = new Stopwatch();
                    stw.Start();
                    long result = SumNumbers(10000000);
                    stw.Stop();
                    Console.WriteLine("线程ID:{0},执行完成,执行结果:{1},执行用时{2},", Thread.CurrentThread.ManagedThreadId, result, stw.ElapsedMilliseconds);
                };
    
                
                ThreadPool.QueueUserWorkItem(wc1);
                ThreadPool.QueueUserWorkItem(wc2);
                ThreadPool.QueueUserWorkItem(wc3);
    
                Console.ReadKey();
            }
    
            static long SumNumbers(int count)
            {
                long sum = 0;
                for (int i = 0; i < count; i++)
                {
                    sum += i;
                }
                Thread.Sleep(1000);
                return sum;
            }
        }

    执行结果:

    2. 等待线程池的线程执行

        class Program
        {
            static void Main(string[] args)
            {
                using (ManualResetEvent m1 = new ManualResetEvent(false))
                using (ManualResetEvent m2 = new ManualResetEvent(false))
                using (ManualResetEvent m3 = new ManualResetEvent(false))
                {
                    ThreadPool.QueueUserWorkItem(
                        s =>{
                            Console.WriteLine("线程ID:{0},开始执行", Thread.CurrentThread.ManagedThreadId);
                            Stopwatch stw = new Stopwatch();
                            stw.Start();
                            long result = SumNumbers(10000000);
                            stw.Stop();
                            m1.Set();
                            Console.WriteLine("线程ID:{0},执行完成,执行结果:{1},执行用时{2},", Thread.CurrentThread.ManagedThreadId, result, stw.ElapsedMilliseconds);
                        });
    
                    ThreadPool.QueueUserWorkItem(
                        s =>{
                            Console.WriteLine("线程ID:{0},开始执行", Thread.CurrentThread.ManagedThreadId);
                            Stopwatch stw = new Stopwatch();
                            stw.Start();
                            long result = SumNumbers(10000000);
                            stw.Stop();
                            m2.Set();
                            Console.WriteLine("线程ID:{0},执行完成,执行结果:{1},执行用时{2},", Thread.CurrentThread.ManagedThreadId, result, stw.ElapsedMilliseconds);
                        });
                    ThreadPool.QueueUserWorkItem(
                        s =>{
                            Console.WriteLine("线程ID:{0},开始执行", Thread.CurrentThread.ManagedThreadId);
                            Stopwatch stw = new Stopwatch();
                            stw.Start();
                            long result = SumNumbers(10000000);
                            stw.Stop();
                            m3.Set();
                            Console.WriteLine("线程ID:{0},执行完成,执行结果:{1},执行用时{2},", Thread.CurrentThread.ManagedThreadId, result, stw.ElapsedMilliseconds);
                        });
    
                    //等待线程池的线程执行
                    m1.WaitOne();
                    m2.WaitOne();
                    m3.WaitOne();
                    Console.WriteLine("所有线程执行完成");
    
                }
    
                Console.ReadKey();
            }
    
            static long SumNumbers(int count)
            {
                long sum = 0;
                for (int i = 0; i < count; i++)
                {
                    sum += i;
                }
                Thread.Sleep(3000);
                return sum;
            }
        }

    执行结果:

  • 相关阅读:
    提取 Microsoft.ReportViewer.ProcessingObjectModel.dll Microsoft.ReportViewer.DataVisualization.dll 等dll(转贴)
    Windows API 逐个逐个学(0) MessageBox
    asp程序员使用asp.net中服务器控件的困惑
    SQLServer 存储过程中不拼接SQL字符串实现多条件查询
    工作学习笔记
    c#3.0/3.5 中的一些新特性
    firefox中使用ctrl+0解决了一个调试很长时间的问题
    使用Nunit进行单元测试
    asp.net 用户控件和自定义控件总结
    Visual Studio 2008 无法启动调试.找不到Microsoft Internet Explorer
  • 原文地址:https://www.cnblogs.com/ChengWenHao/p/CSharpThreadPool.html
Copyright © 2011-2022 走看看