首页 > 编程语言 > 详细

JAVA并发编程>>线程池的实现

时间:2019-04-15 20:12:03      阅读:121      评论:0      收藏:0      [点我收藏+]

线程创建倾向

如果运行的线程的小于corePoolSize,当请求来时,创建新线程。

如果运行corePoolSize或多于,当请求来时,排队。

如果请求不能进行排队,且小于maximumPoolSize创建新线程,请求会被拒绝。

不要使用Executors.newXXXThreadPool()快捷方法创建线程池,因为这种方式会使用无界的任务队列,为避免OOM。

1、创建线程池

 1 package com.learn.threadTest;
 2 
 3 
 4 import java.util.concurrent.ArrayBlockingQueue;
 5 import java.util.concurrent.ExecutorService;
 6 import java.util.concurrent.TimeUnit;
 7 import java.util.concurrent.ThreadPoolExecutor;
 8 
 9 public class DefineThreadPoolFactory {
10     
11 
12     private final static int corePoolSize = 5;//活跃线程数
13     private final static int maximumPoolSize = 20;//最大线程数
14     private final static long keepAliveTime = 0;//临时线程活跃时长
15     
16     public static ExecutorService threadPoolFactory () {
17         ExecutorService executorService = new ThreadPoolExecutor(corePoolSize,maximumPoolSize,keepAliveTime,TimeUnit.SECONDS,new ArrayBlockingQueue<>(128));
18         return executorService;
19     }
20     public static void main(String[] arg0) {
21         threadPoolFactory().submit(new Runnable() {
22             @Override
23             public void run() {
24                 Thread.currentThread().setName("虾来了");
25                 System.out.println("获取到线程资源,线程名{"+Thread.currentThread().getName()+"}");
26                 System.out.println("获取到线程资源,线程名{"+Thread.currentThread().getId()+"}");
27             }
28         });
29     }
30 }

执行结果

技术分享图片

创建线程是昂贵的开销,请合理创建线程。另外,所有线程,请设定一个有意义的名字,方便问题排查。

JAVA并发编程>>线程池的实现

原文:https://www.cnblogs.com/zhujj1314/p/10712682.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!