码迷,mamicode.com
首页 > 编程语言 > 详细

线程池

时间:2018-10-06 15:33:16      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:run   sub   java   int   线程池   接收   throw   产生   task   

Executors(线程池)

(jdk1.5特性)
  jdk1.5之前,我们必须要手动实现自己的线程池,jdk1.5之后,Java内置支持线程池
? 线程池的优点
  线程池里的每一个线程代码结束后,并不会死亡,而是再次回到线程池中成为空闲状态,等待下一个对象来使用。
? 和线程池相关的类和方法
  Executors工厂类(用于产生线程池):
    public static ExecutorService newCachedThreadPool()
    public static ExecutorService newFixedThreadPool(int nThreads)
    创建一个线程池对象,并控制要创建几个线程对象
    public static ExecutorService newSingleThreadExecutor()
    创建一个线 程池对象,并只有一个线程对象
  ExecutorService接口(用于执行Runnable对象或者Callable对象代表的线程):
    Future<?> submit(Runnable task)        执行Runnable对象代表的线程
    <T> Future<T> submit(Callable<T> task)    执行Callable对象代表的线程
    void shutdown()                启动一次顺序关闭,执行以前提交的任务,但不接受新任务
  Callable<V>接口(第三种创建线程的方式,依赖于线程池使用,这里指定的泛型是call()方法的返回值类型)
    V call() throws Exception 计算结果并返回,类似于带返回值、可以抛异常run()方法
  Future接口(泛型接口,表示异步计算的结果,这里指定的泛型与 Callable 中的泛型一致)
    V get() 返回计算的结果,需要用引用类型接收
? 示例代码:
  // 创建一个线程池对象,控制要创建几个线程对象
    ExecutorService pool = Executors.newFixedThreadPool(2);
  // 可以执行Runnable对象或者Callable对象代表的线程
    pool.submit(new MyRunnable());
    pool.submit(new MyRunnable());
  //结束线程池
    pool.shutdown();

线程池

标签:run   sub   java   int   线程池   接收   throw   产生   task   

原文地址:https://www.cnblogs.com/bbbbbbbb1og/p/9747355.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!