java引发死锁的四种情况

四种情况

1、交叉锁导致程序死锁:比如线程A持有R1的锁等待R2的锁,线程B持有R2的锁等待R1的锁

2、内存不足:比如两个线程T1和T2,T1已获取10MB内存,T2获取了15MB内存,T1和T2都需要获取30MB内存才能工作,但是剩余可用的内存为10MB,这样两个线程都在等待彼此释放内存资源

3、一问一答式的数据交换:服务器开启某个端口,等待客户端访问,客户端发送请求后,服务器因某些原因错过了客户端请求,导致客户端等待服务器回应,而服务器等待客户端发送请求

4、死循环引起的死锁:比较常见,使用jstack等工具看不到死锁,但是程序不工作,CPU占有率高,这种死锁也叫系统假死,难以排查和重现

实例

publicclassMain{
privatefinalObjectMUTEX_READ=newObject();
privatefinalObjectMUTEX_WRITE=newObject();

publicvoidread(){
synchronized(MUTEX_READ){
synchronized(MUTEX_WRITE){
}
}
}

publicvoidwrite(){
synchronized(MUTEX_WRITE){
synchronized(MUTEX_READ){
}
}
}

publicstaticvoidmain(String[]args)throwsInterruptedException{
Mainm=newMain();
newThread(()->{
while(true){
m.read();
}
}).start();
newThread(()->{
while(true){
m.write();
}
}).start();
}
}

以上就是java引发死锁的四种情况,希望对大家有所帮助。更多Java学习指路:Java基础

原文来自:https://www.py.cn
© 版权声明
THE END
喜欢就支持一下吧
点赞10 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容