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

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

发布时间:2019-04-01 20:07:41 所属栏目:建站 来源:程序员柯南
导读:01.无穷制线程的弱点 多线程的软件计划要领确实可以最大限度地施展多核处理赏罚器的计较手段,提跨越产体系的吞吐量和机能。可是,若不加节制和打点的随意行使线程,对体系的机能反而会发生倒霉的影响。 一种最为简朴的线程建设和接纳的要领相同如下: newThre

关于ThreadPoolExecutor ,前面第3节已经具体论述。ScheduledThreadPoolExecutor 也是ExecutorService接口的实现类,可以在给定的耽误后运行呼吁,可能按期执行呼吁。ScheduledThreadPoolExecutor 比 Timer 更机动,成果更强盛。

4.4 Future与FutureTask

上面的示例中行使 execute() 要领提交使命,,用于提交不必要返回值的使命。假如我们必要获取执利用命之后的返回值,可以行使submit()要领。

示例代码:

  1. public static void main(String[] args) throws InterruptedException, ExecutionException { 
  2.         //新建一个线程池 
  3.         ExecutorService executor = Executors.newCachedThreadPool(); 
  4.         List<Future> futureList = new Vector<>(); 
  5.         //在其余线程中执行100次下列要领 
  6.         for (int i = 0; i < 100; i++) { 
  7.             futureList.add(executor.submit(new Callable<String>() { 
  8.                 @Override 
  9.                 public String call() throws Exception { 
  10.                     return Thread.currentThread().getName()+" "+System.currentTimeMillis()+" "; 
  11.                 } 
  12.             })); 
  13.         } 
  14.         for (int i = 0;i<futureList.size();i++){ 
  15.             Object o = futureList.get(i).get(); 
  16.             System.out.println(o.toString()+i); 
  17.         } 
  18.         executor.shutdown(); 
  19.     } 

运行功效:

  1. ... 
  2. pool-1-thread-11 1537872778612 96 
  3. pool-1-thread-11 1537872778613 97 
  4. pool-1-thread-10 1537872778613 98 
  5. pool-1-thread-10 1537872778613 99 

到这里,就不得不提Future接口与FutureTask实现类,它们代表异步计较的功效。

  1. Future<T> submit(Callable<T> task) 
  2. Future<?> submit(Runnable task); 
  3. Future<T> submit(Runnable task, T result); 

当我们submit()提交后,会返回一个Future工具,到JDK1.8,返回的现实是FutureTask实现类。submit() 要领支持 Runnable 或 Callable 范例的参数。Runnable 接口 和Callable 接口的区别就是 Runnable 不会返回功效,Callable 会返回功效。

主线程可以执行 futureTask.get() 要领来阻塞当前列程直到使命执行完成,使命完成后返回使命执行的功效。

futureTask.get(long timeout, TimeUnit unit) 要领例会阻塞当前列程一段时刻当即返回,这时辰有也许使命没有执行完。

主线程也可以执行 futureTask.cancel(boolean mayInterruptIfRunning) 来打消此使命的执行。

futureTask.isCancelled要领暗示使命是否被打消乐成,假如在使命正常完成前被打消乐成,则返回 true。

futureTask.isDone要领暗示使命是否已经完成,若使命完成,则返回true。

【编辑保举】

  1. Java 8顶用法优雅的Stream,机能也"优雅"吗?
  2. Web机能优化:领略及行使JavaScript缓存
  3. Java开拓者但愿将来行使Python和Go
  4. 未来会是Python、Java、Golang鼎足之势的排场吗?
  5. 几行JavaScript代码构建计较机视觉措施,这里有6个js框架
【责任编辑:武晓燕 TEL:(010)68476606】
点赞 0

(编辑:湖南网)

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

热点阅读