Executor和Thread的区别,什么时候用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时也没提示过时啊。

阅读 8.3k
1 个回答

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏