- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
8 种让线程挨次执行的方式,你晓得吗?
本文使用了 7 中方法实现在多线程中让线程按挨次运转的方法,涉及到多线程中很多常用的方法,不止为了晓得如何让线程按挨次运转,更是让读者对多线程的使用有更深刻的了解。使用的方法如下:
[1] 使用线程的 join 方法[2] 使用主线程的 join 方法[3] 使用线程的 wait 方法[4] 使用线程的线程池方法[5] 使用线程的 Condition(条件变量)方法 [6] 使用线程的 CountDownLatch(倒计数)方法[7] 使用线程的 CyclicBarrier(回环栅栏)方法[8] 使用线程的 Semaphore(信号量)方法
我们下面需要完成这样一个应用场景:
1.早上;2.测试人员、产品经理、开发人员间续的来公司上班;3.产品经理规划新需求;4.开发人员开发新需求功能;5.测试人员测试新功能。
规划需求,开发需求新功能,测试新功能是一个有挨次的,我们把 thread1 看做产品经理,thread2 看做开发人员,thread3 看做测试人员。
1.使用线程的 join 方法
join():是 Theard 的方法,作用是调用线程需等待该 join()线程执行完成后,才能连续用下运转。
应用场景:当一个线程必需等待另一个线程执行完毕才能执行时可以使用 join 方法。
package?com.wwj.javabase.thread.order;public?class?ThreadJoinDemo?{????public?static?void?main(String[]?args)?{????????final?Thread?thread1?=?new?Thread(new?Runnable()?{????????????@Override????????????public?void?run()?{????????????????System.out.println(产品经理规划新需求);????????????}????????});????????final?Thread?thread2?=?new?Thread(new?Runnable()?{????????????@Override????????????public?void?run()?{????????????????try?{????????????????????thread1.join();????????????????????System.out.println(开发人员开发新需求功能);????????????????}?catch?(InterruptedException?e)?{????????????????????e.printStackTrace();????????????????}????????????}????????});????????Thread?thread3?=?new?Thread(new?Runnable()?{????????????@Override????????????public?void?run()?{????????????????try?{????????????????????thread2.join();????????????????????System.out.println(测试人员测试新功能);????????????????}?catch?(InterruptedException?e)?{????????????????????e.printStackTrace();????????????????}????????????}????????});????????System.out.println(早上:);????????System.out.println(测试人员来上班了...);????????thread3.start();????????System.out.println(产品经理来上班了...);????????thread1.start();????????System.out.println(开发人员来上班了...);????????thread2.start();????}}
运转结果
早上:测试人员来上班了... 产品经理来上班了... 开发人员来上班了... 产品经理规划新需求 开发人员开发新需求功能 测试人员测试新功能
2.使用主线程的 join 方法
这里是在主线程中使用 join()来实现对线程的堵塞。
package?com.wwj.javabase.thread.order;publi
您可能关注的文档
- 张图梳理 Intellij IDEA 常用设置.docx
- . 万亿条数据查询,如何做到毫秒级响应?.docx
- ClickHouse全面解析,看这一篇文章就够了.docx
- Elasticsearch 在业界的大量应用案例.docx
- HDFS .x 升级到 .x 在车好多的实践.docx
- Hbase、Kudu 和 ClickHouse 全面对比(万字、张图).docx
- Jar 包依赖冲突很烦人,总结一波排查思路和解决方法.docx
- Java中的方法引用.docx
- Java生鲜电商平台SpringCloud微服务架构中分布式事务解决方案.docx
- JetBrains出品,一款好用到爆的数据库工具,惊艳到了!!!.docx
文档评论(0)