join方法及其调用yield sleep wait notify方法会对锁产生的影响
join方法
线程A执行了线程B的join方法,,线程A必须要等线程B执行完成后,线程A才能继续执行
感觉像是插队[捂脸]
package org.dance.day1; import org.dance.tools.SleepTools; /** * join方法的使用 */ public class UseJoin { // static class JumpQueue implements Runnable { private Thread thread;//用来插队的线程 public JumpQueue(Thread thread) { this.thread = thread; } @Override public void run() { try { System.out.println(thread.getName()+" will be join before " +Thread.currentThread().getName()); thread.join(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+" terminted."); } } public static void main(String[] args) throws Exception { Thread previous = Thread.currentThread();//现在是主线程 for (int i = 0; i < 10; i++) { //i=0,previous 是主线程,i=1;previous是i=0这个线程 Thread thread = new Thread(new JumpQueue(previous), String.valueOf(i)); System.out.println(previous.getName()+" jump a queue the thread:" +thread.getName()); thread.start(); previous = thread; } SleepTools.second(2);//让主线程休眠2秒 System.out.println(Thread.currentThread().getName() + " terminate."); } }
接下来说一下调用yield sleep wait notify方法会对锁产生的影响
yield:
线程在执行yield以后,持有的锁是不会释放的
sleep:
线程在进入Sleep之后,锁也是不会释放的
wait:
调用wait方法之前,必须要先持有锁,调用wait方法以后,锁会被释放,当wait方法被唤醒时,线程会重新持有锁
notify:
调用notify之前,也必须要持有锁,调用notify方法本身不会释放锁
作者:彼岸舞
时间:2020\09\16
内容关于:并发编程
本文来源于网络,只做技术分享,一概不负任何责任
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」