[19/04/10-星期三] 多线程_死锁及解决措施
一、概念
“死锁”指的是: 多个线程各自占有一些共享资源,并且互相等待其他线程占有的资源才能进行,而导致两个或者多个线
程都在等待对方释放资源,都停止执行的情形。 因此, 某一个同步块需要同时拥有“两个以上对象的锁”时,就可能会发生“死锁”的问题。
下面案例中,“化妆线程”需要同时拥有“镜子对象”、“口红对象”才能运行同步块。那么,实际运行时,“小丫的化妆线程”拥有了“镜子对象”,
“大丫的化妆线程”拥有了“口红对象”,都在互相等待对方释放资源,才能化妆。这样,两个线程就形成了互相等待,无法继续运行的“死锁状态”。
/*** * 死锁:过多的同步可能造成相互不释放资源从而导致死锁,一般反生与同步中持有多个对象的锁 * 避免: * 不要在同一代码块中持有多个对象的锁 */ package cn.sxt.thread; public class Test_0410_DeadLock { public static void main(String[] args) { Makeup g1=new Makeup(1, "小红"); Makeup g2=new Makeup(0, "小丽"); g1.start(); g2.start(); } } //口红类 class Lipstick{ } //镜子类 class Mirror{ } //化妆类 class Makeup extends Thread{ int choice; String girl; static Lipstick lipstick=new Lipstick();//static加static表示一份,不管创建几个对象。一个口红 static Mirror mirror=new Mirror();//一面镜子 public Makeup(int choice,String girl) { super(); this.choice = choice; this.girl=girl; } public void run() { core(); } //化妆核心代码 相互持有对方的对象锁,则可能造成死锁 private void core(){ if (choice==0) { synchronized (lipstick) {//获得口红的锁 System.out.println(this.girl+"涂口红"); //1秒后想拿镜子 try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } /*synchronized (mirror) { //造成死锁的代码 System.out.println(this.girl+"照镜子"); }*/ } synchronized (mirror) { //把代码移动出来,不要锁套锁 System.out.println(this.girl+"照镜子"); } }else { synchronized (mirror) {//获得镜子的锁 System.out.println(this.girl+"照镜子"); //2秒后想拿口红 try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } /*synchronized (lipstick) {//造成死锁的代码,锁套锁 System.out.println(this.girl+"涂口红"); }*/ } synchronized (lipstick) {//移动出来 System.out.println(this.girl+"涂口红"); } } } }

浙公网安备 33010602011771号