死锁问题的描述和代码体现

简介: 死锁问题的描述和代码体现   同步弊端:效率低;如果出现了同步嵌套,就容易产生死锁问题。   死锁问题:是指两个或者两个以上的线程在执行的过程中,因争夺资源产生的一种互相等待现象。 同步代码块的嵌套案例代码如下: 1 package cn.

死锁问题的描述和代码体现

  同步弊端:效率低;如果出现了同步嵌套,就容易产生死锁问题。
  死锁问题:是指两个或者两个以上的线程在执行的过程中,因争夺资源产生的一种互相等待现象。

同步代码块的嵌套案例代码如下:

1 package cn.itcast_02;
2 
3 public class MyLock {
4     // 创建两把锁对象
5     public static final Object objA = new Object();
6     public static final Object objB = new Object();
7 }
 1 package cn.itcast_02;
 2 
 3 public class DieLock extends Thread {
 4 
 5     private boolean flag;
 6 
 7     public DieLock(boolean flag) {
 8         this.flag = flag;
 9     }
10 
11     @Override
12     public void run() {
13         if (flag) {
14             synchronized (MyLock.objA) {
15                 System.out.println("if objA");
16                 synchronized (MyLock.objB) {
17                     System.out.println("if objB");
18                 }
19             }
20         } else {
21             synchronized (MyLock.objB) {
22                 System.out.println("else objB");
23                 synchronized (MyLock.objA) {
24                     System.out.println("else objA");
25                 }
26             }
27         }
28     }
29     
30 }
 1 package cn.itcast_02;
 2 
 3 /*
 4  * 同步的弊端:
 5  *         A:效率低
 6  *         B:如果出现了同步嵌套,就容易产生死锁问题
 7  * 
 8  * 死锁:
 9  *         是指两个或者两个以上的线程在执行的过程中,因争夺资源产生的一种互相等待现象。
10  * 
11  * 举例:
12  *         中国人和美国人一起吃饭案例。
13  *         正常情况:
14  *             中国人:筷子两支
15  *             美国人:刀和叉
16  *         现在:
17  *             中国人:筷子1支,刀一把
18  *             美国人:筷子1支,叉一把
19  */
20 public class DieLockDemo {
21     public static void main(String[] args) {
22         DieLock dl1 = new DieLock(true);
23         DieLock dl2 = new DieLock(false);
24 
25         dl1.start();
26         dl2.start();
27     }
28 }
理想情况下程序的运行结果为:
if objA if objB else objB else objA 或者 else objB else objA if objA if objB 死锁情况下程序的运行结果为:
if objA else objB 或者 else objB if objA 这四种程序运行结果都有可能发生!

 

我的GitHub地址: https://github.com/heizemingjun
我的博客园地址: http://www.cnblogs.com/chenmingjun
我的蚂蚁笔记博客地址: http://blog.leanote.com/chenmingjun
Copyright ©2018 黑泽明军
【转载文章务必保留出处和署名,谢谢!】
相关文章
|
6月前
|
安全 算法 程序员
|
6月前
|
安全
什么是死锁?互斥锁进入死锁怎么解决?
什么是死锁?互斥锁进入死锁怎么解决?
|
6月前
|
算法 安全
解决死锁的方法
解决死锁的方法
|
6月前
死锁的发生与避免
死锁的发生与避免 死锁是指两个或者多个进程在执行过程中,因争夺资源而造成的一种僵局,若无外力作用,它们都将无法推进下去。在计算机系统中,死锁是一种常见的问题,因此需要采取一些措施来避免死锁的发生。
|
安全 算法
死锁的总结(1)
死锁的总结
33 0
|
算法 安全
死锁的总结(2)
死锁的总结
49 0
|
算法 安全 Java
死锁的原理
之前在学校学习过程中,很少写多进程的代码,虽然操作系统中学过死锁相关的内容,但考试过后也基本就忘记了,后来自己也遇到过有些多进程死锁的情况,再加上看了有些资料,对死锁才算是有了有些深入的理解。
81 0
|
存储 关系型数据库 MySQL
面试官:解释下什么是死锁?为什么会发生死锁?怎么避免死锁?
开局先来个段子: 面试官: 解释下什么是死锁? 应聘者: 你录用我,我就告诉你 面试官: 你告诉我,我就录用你 应聘者: 你录用我,我就告诉你 面试官: 滚!
|
程序员 Linux 芯片