开发者社区> 问答> 正文

Executor和Thread的区别

蛮大人123 2016-02-25 18:18:19 1137

刚自学到多线程这章,感觉很迷茫。
看一个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时也没提示过时啊

分享到
取消 提交回答
全部回答(5)
  • chankan
    2019-07-17 18:47:51

    建议使用executor,直接new thread线程数量没法统一控制,并且初始化线程是有开销的

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

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

    0 0
  • 蛮大人123
    2019-07-17 18:47:50

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

    0 0
添加回答

集结各类场景实战经验,助你开发运维畅行无忧

推荐文章
相似问题