刚自学到多线程这章,感觉很迷茫。
看一个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时也没提示过时啊
线程的创建和销毁是很耗时的,Thread就是这样的一个东西,Executor就是这样一个东西的集合,所以java提供了一个Runable接口,只要把这个接口的实现类叫个线程去执行里面的run方法就行了,Executor不会一直创建和销毁线程。java的这个线程里面的设计模式叫模板方法模式
Executor使用线程池来管理线程,可以重复利用已经创建出来的线程而不是每次都必须新创建线程,节省了一部分的开销。 线程池也可以很方便的管理线程的大小和当前在执行的线程数量。 你可以认为Executor是帮助你管理Thread的一个前人帮你封装好的工具。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。