开发者社区> 问答> 正文

Executor和Thread的区别

刚自学到多线程这章,感觉很迷茫。
看一个java视频时,几乎全是用Thread类来处理多线程。
但是看Thinking in java时,里面几乎全部用Executor来处理实现Runnable类的对象已完成多线程的处理。
我现在还是不明白两者具体区别是什么?Executor看起来更安全、更自动化管理线程,两者也可以混用,如:
ExecutorService pool=Executors.newCachedThreadPool();
Thread t1=new MultiThread(); //MultiThread 集成了Thread类,从而实现了Runnable接口。
pool.execute(t1);
pool.shutdown();
是不是Executor在jdk1.6以后的版本过时了还是怎么回事?我看jdk7版本API时也没提示过时啊

展开
收起
蛮大人123 2016-02-25 18:18:19 5189 0
5 条回答
写回答
取消 提交回答
  • 建议使用executor,直接new thread线程数量没法统一控制,并且初始化线程是有开销的

    2019-07-17 18:47:51
    赞同 展开评论 打赏
  • 1、能够实现高并发和低延迟。 2、因为Executor的实现类可以很好的管理其线程的创建数量,可能任务提交给Executor的时候,已经有可以执行此任务的线程了,这样减少了 线程创建带来的延迟。因为Executor实例限制了,创建线程的数量,减少了线程之间对CPU的竞争,也在一定程度上提高了系统性能。对线程创建数量的限制,保证了系统的稳定性。 3、更加灵活的执行策略,因为Executor实现了任务的提交和执行的解耦,可以让我们灵活的更换任务的执行策略。 4、继承Executor接口的ExecutorService增加了生命周期的管理,更加贴近真实的生产开发。
    2019-07-17 18:47:51
    赞同 展开评论 打赏
  • executor是一个任务,由独立的线程池来执行。thread是一个独立线程,独立执行
    2019-07-17 18:47:50
    赞同 展开评论 打赏
  • 技术源于生活

    线程的创建和销毁是很耗时的,Thread就是这样的一个东西,Executor就是这样一个东西的集合,所以java提供了一个Runable接口,只要把这个接口的实现类叫个线程去执行里面的run方法就行了,Executor不会一直创建和销毁线程。java的这个线程里面的设计模式叫模板方法模式

    2019-07-17 18:47:50
    赞同 展开评论 打赏
  • 我说我不帅他们就打我,还说我虚伪

    Executor使用线程池来管理线程,可以重复利用已经创建出来的线程而不是每次都必须新创建线程,节省了一部分的开销。 线程池也可以很方便的管理线程的大小和当前在执行的线程数量。 你可以认为Executor是帮助你管理Thread的一个前人帮你封装好的工具。

    2019-07-17 18:47:50
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载