java避免死锁的常见方法代码解析

所属分类: 软件编程 / java 阅读数: 17
收藏 0 赞 0 分享

死锁

索是一个非常有用的工具,运用场景非常多,因为它使用起来非常简单,而且易于理解。但同时它也会带来一些困扰,那就是可能会引起死锁,一旦产生死锁,就会造成系统功能不可用。让我们先来看一段代码,这段代码会引起死锁,使线程 thread_1 和线程 thread_2 互相等待对方释放锁。

package thread;
public class DeadLockDemo {
	private static String A = "A";
	private static String B = "B";
	public static void main(String args[]) {
		new DeadLockDemo().deadLock();
	}
	private void deadLock() {
		// 线程thread_1 
		Thread thread_1 = new Thread(new Runnable() {
			@Override 
			   public void run() {
				synchronized (A) {
					System.err.println("--thread_1 lock A----");
					synchronized (B) {
						System.err.println("--thread_1 lock B----");
					}
				}
			}
		}
		);
		// 线程thread_2 
		Thread thread_2 = new Thread(new Runnable() {
			@Override 
			   public void run() {
				synchronized (B) {
					System.out.println("--thread_2 lock B----");
					synchronized (A) {
						System.out.println("--thread_2 lock A----");
					}
				}
			}
		}
		);
		thread_1.start();
		thread_2.start();
	}
}

这段代码只是演示死锁的场景,在现实中你可能不会写出这样的代码。但是在一些更为复杂的场景中,你可能会遇到这样的问题,比如 thread_1 拿到索之后,因为一些异常情况没有释放索(死循环)。又或者是 thread_1 拿到一个数据库索,释放锁的时候抛出了异常,没释放掉。

一旦出现死锁,业务是可感知的,因为不能继续提供服务了,那么只能通过dump 线程查看到底是哪个线程出现了问题,以下线程信息告诉我们是 DeadLockDemo类的第 35 行和21行引起了死锁。

"Thread-1" prio=6 tid=0x000000000cb13800 nid=0x19ac waiting for monitor entry [0 
x000000000d67f000] 
 java.lang.Thread.State: BLOCKED (on object monitor) 
  at thread.DeadLockDemo$2.run(DeadLockDemo.java:35) 
  - waiting to lock <0x00000007d5a9be88> (a java.lang.String) 
  - locked <0x00000007d5a9beb8> (a java.lang.String) 
  at java.lang.Thread.run(Unknown Source) 
 
"Thread-0" prio=6 tid=0x000000000cb0e800 nid=0x6bc waiting for monitor entry [0x 
000000000d48f000] 
 java.lang.Thread.State: BLOCKED (on object monitor) 
  at thread.DeadLockDemo$1.run(DeadLockDemo.java:21) 
  - waiting to lock <0x00000007d5a9beb8> (a java.lang.String) 
  - locked <0x00000007d5a9be88> (a java.lang.String) 
  at java.lang.Thread.run(Unknown Source) 

避免死锁的几个常见方法。

避免一个线程同时获取多个锁。

避免一个线程在索内同时占用多个资源,尽量保证每个索只占用一个资源。

尝试使用定时索,使用 lock.tryLock(timeout) 来替代使用内部索机制。

对于数据库索,加锁和解锁必须在一个数据库连接里,否则会出现解锁失败的情况。

referance:

https://www.jb51.net/article/131946.htm

https://www.jb51.net/article/131943.htm

总结

以上就是本文关于java避免死锁的常见方法代码解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

更多精彩内容其他人还在看

Java数据类型的规则

这篇文章主要介绍了Java数据类型的规则的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

Spring整合TimerTask实现定时任务调度

这篇文章主要介绍了Spring整合TimerTask实现定时任务调度的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

详解SpringMVC使用MultipartFile实现文件的上传

本篇文章主要介绍了SpringMVC使用MultipartFile实现文件的上传,本地的文件上传到资源服务器上,比较好的办法就是通过ftp上传。这里是结合SpringMVC+ftp的形式上传的,有兴趣的可以了解一下。
收藏 0 赞 0 分享

SpringMVC上传文件的三种实现方式

本篇文章主要介绍了SpringMVC上传文件的三种实现方式,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

微信公众帐号开发-自定义菜单的创建及菜单事件响应的实例

本篇文章主要介绍了微信公众帐号开发-自定义菜单的创建及菜单事件响应的实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
收藏 0 赞 0 分享

浅析Java中的继承与组合

本文将介绍组合和继承的概念及区别,并从多方面分析在写代码时如何进行选择。文中通过示例代码介绍的很详细,有需要的朋友可以参考借鉴,下面来一起看看吧。
收藏 0 赞 0 分享

利用反射获取Java类中的静态变量名及变量值的简单实例

下面小编就为大家带来一篇利用反射获取Java类中的静态变量名及变量值的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

java启动线程的3种方式对比分析

这篇文章主要为大家对比分析了java启动线程的3种方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

SpringMVC上传和解析Excel方法

这篇文章主要介绍了SpringMVC上传和解析Excel方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

JAVA中String类与StringBuffer类的区别

这篇文章主要为大家详细介绍了JAVA中String类与StringBuffer类的区别,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享
查看更多