线程池的使用

使用场景:大批量的数据运算使用异步分批次运算后cpu报警,代码分析为异步线程开的太多造成cpu处理瓶颈,现在以时间换取空间使用线程池限制工作的线程数量。并减轻线程创建销毁缩占用的资源,但是需要更长的运算时间

使用效果:限制只有规定的几个线程工作,减轻服务器压力。

实现步骤:生成一个代理类Hepler,用于定义线程池信息

public class Hepler
    {
        static Hepler()
        {
            ThreadPool.SetMaxThreads(3, 3);
            ThreadPool.SetMinThreads(1, 1);
        }

        //异步处理委托方法
        public static bool InvokeAsync(Action action)
        {
          return ThreadPool.UnsafeQueueUserWorkItem(delegate { action.BeginInvoke(Callback,null); }, null);
        }   
        //异步回调函数,用于停止异步。因为等待异步资源回收需要一段时间 所以在方法结束时及时的结束异步释放资源
        public static void Callback(IAsyncResult result)
        {
       
Console.WriteLine("结束一个异步");
       Action action = ((Action)result.AsyncState);
  action.EndInvoke(result);
     }

调用处使用

 static void Main(string[] args)
        {
            for (int i = 0; i < 100; i++)
            {
                if (Hepler.InvokeAsync(delegate { Console.WriteLine(Thread.CurrentThread.IsThreadPoolThread); Thread.Sleep(5000); }))
                {
                    continue;
                }
            }

            Console.ReadLine();
        }

代码运行结果:新创建的线程全部属于线程池,并且最多会有3个线程在运行

 

转载于:https://www.cnblogs.com/FLoveZ/p/9268756.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值