四种情况
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基础
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
暂无评论内容