Java正确创建线程池方式

  PS:最近换工作,被问到多次线程池的问题 例如 线程池的几种实现方式,怎样创建一个线程池等等。也是前段时间阿里发布了Java代码约束工具,规定不建议使用Executors去直接创建线程,而是通过ThreadPoolExcutor的方式,规则如下:

线程池不允许使用Executors去创建,而是通过ThreadPoolExecutor的方式,这样的处理方式让写的同学更加明确线程池的运行规则,规避资激耗尽的风险。
说明:Executors各个方法的弊端:
1) newFixedThreadPoolfPnewSingleThreadExecutor:
主要问题是堆积的请求处理队列可能会耗费非常大的内存,甚至00M。
2) newCachedThreadPoolfPnewScheduledThreadPool:
主要问題是线程数最大数是Integer.MAX_VALUE,可能会创建数置非常多的线程,甚至00M。

Positive example 1:

//org.apache.commons.Iang3.concurrent.BasicThreadFactory
ScheduledExecutorService executorService = new ScheduledThreadPoolExecutor(l,
          new BasicThreadFactory.Builder().namingPattern(Mexample-schedule-pool-%d").daemon(true).build());
Positive example 2:

ThreadFactory namedThreadFactory = new ThreadFactoryBuilder()
.setNameFormat(Mdemo-pool-%d").build();
//Common Thread Pool
ExecutorService pool = new ThreadPoolExecutor(5, 200,
   0L, TimeUnit.MILLISECONDS,
   new LinkedBlockingQueue<Runnable>(1024), namedThreadFactory, new ThreadPoolExecutor.AbortPolicy());
pool.execute(()-> System.out.println(Thread.currentThread().getName()));
pool.shutdown() "/gracefully shutdown
Positive example 3:

<bean id="userThreadPoolM
class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
	<property name=McorePoolSize" value="10M />
	<property name=MmaxPoolSize" value="100M />
	<property name=MqueueCapacity" value="2000M />

<property name=MthreadFactoryM value= threadFactory />
	<property name="rejectedExecutionHandlerM>
<ref local="rejectedExecutionHandler" />
</property>
</bean>
//in code
userThreadPool.execute(thread);

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值