刚自学到多线程这章,感觉很迷茫。
看一个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时也没提示过时啊。
Executor使用线程池来管理线程,可以重复利用已经创建出来的线程而不是每次都必须新创建线程,节省了一部分的开销。
线程池也可以很方便的管理线程的大小和当前在执行的线程数量。
你可以认为Executor是帮助你管理Thread的一个前人帮你封装好的工具。