加入收藏 | 设为首页 | 会员中心 | 我要投稿 孝感站长网 (https://www.0712zz.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

Java线程池实现原理与技术,看这一篇就够了

发布时间:2019-04-02 13:29:40 所属栏目:优化 来源:程序员柯南
导读:01.无限制线程的缺点 多线程的软件设计方法确实可以最大限度地发挥多核处理器的计算能力,提高生产系统的吞吐量和性能。但是,若不加控制和管理的随意使用线程,对系统的性能反而会产生不利的影响。 一种最为简单的线程创建和回收的方法类似如下: newThre

或者通过submit()方法提交任务

  1. public static void main(String[] args) throws ExecutionException, InterruptedException { 
  2.         ThreadPoolExecutor executor = new ThreadPoolExecutor(4, 5, 0, TimeUnit.SECONDS, new LinkedBlockingQueue<>()); 
  3.         List<Future> futureList = new Vector<>(); 
  4.         //在其它线程中执行100次下列方法 
  5.         for (int i = 0; i < 100; i++) { 
  6.             futureList.add(executor.submit(new Callable<String>() { 
  7.                 @Override 
  8.                 public String call() throws Exception { 
  9.                     return Thread.currentThread().getName(); 
  10.                 } 
  11.             })); 
  12.         } 
  13.         for (int i = 0;i<futureList.size();i++){ 
  14.             Object o = futureList.get(i).get(); 
  15.             System.out.println(o.toString()); 
  16.         } 
  17.         executor.shutdown(); 
  18.     } 

运行结果:

  1. ... 
  2. pool-1-thread-4 
  3. pool-1-thread-3 
  4. pool-1-thread-2 

下面主要讲解ThreadPoolExecutor的构造方法中workQueue和RejectedExecutionHandler参数,其它参数都很简单。

3.2 workQueue任务队列

(编辑:孝感站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读