面试官:如让线程顺序执行?
我:使用Thread的join方法。
面试官:除了join还有别的办法吗?
我:目前只用过join。
面试官:哦,那你了解CountDownLatch吗?
我:不了解,没使用过。
面试中被问到线程顺序执行,相信大家都能答出来join,但是除了join还有其他的办法,不知道大家了解不。我这里分享下3种方式。
第一种:join
![02fc359637b524d2f0647a227b0b7fb0.png](https://i-blog.csdnimg.cn/blog_migrate/6dd45384ceae6ede3ade85e0856ba1da.jpeg)
join方式
第二种:线程池
通过Executors.newSingleThreadExecutor()来实现(这里可以看我的《面试官问你java都有哪些线程池,自己是否自定义过线程池》)
![d8ba080d1a80c1144c4bc11710211da9.png](https://i-blog.csdnimg.cn/blog_migrate/86015fbd8f6c02018a9cb77dd5859911.jpeg)
线程池
第三种:通过CountDownLatch实现
![33a8fff0e5b329ac1b4fb710dcca2b8a.png](https://i-blog.csdnimg.cn/blog_migrate/1261921036269f80a291ec472f10fb84.jpeg)
CountDownLatch
这3种方式哪种比较好,我个人认为还是CountDownLatch,因为他的粒度更细,比如我上面的例子,t2线程执行一半,t3线程就可以执行,通过join和线程池都实现不了。而通过CountDownLatch可以实现,如图:
![be35d638005eae549ca5ab736f8e1a39.png](https://i-blog.csdnimg.cn/blog_migrate/b029664ac334e8de9baa7426fc9743a8.jpeg)
CountDownLatch细粒度
总结:
选择使用什么样的方式,取决于你的需求,如果你只是想顺序的执行那join和线程池都可以使用,因为这2种方式比较简单。如果需求是细粒度的,比如线程1执行到某个部分,线程2就得执行,就使用CountDownLatch。但是使用它时,一定要理清逻辑,不然可能await方法会阻塞。