zoukankan      html  css  js  c++  java
  • java中的死锁现象

    死锁是这样一种情形:多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放。由于线程被无限期地阻塞,因此程序不可能正常终止。

    java 死锁产生的四个必要条件:

    • 1、互斥使用,即当资源被一个线程使用(占有)时,别的线程不能使用
    • 2、不可抢占,资源请求者不能强制从资源占有者手中夺取资源,资源只能由资源占有者主动释放。
    • 3、请求和保持,即当资源请求者在请求其他的资源的同时保持对原有资源的占有。
    • 4、循环等待,即存在一个等待队列:P1占有P2的资源,P2占有P3的资源,P3占有P1的资源。这样就形成了一个等待环路。

    当上述四个条件都成立的时候,便形成死锁。当然,死锁的情况下如果打破上述任何一个条件,便可让死锁消失。下面用java代码来模拟一下死锁的产生。

    而如果不恰当的使用了锁,且出现同时要锁多个对象时,会出现死锁情况,如下:

    package lance.Thread;
    
    import java.util.Date;
    
    /**
     * 死锁测试
     * 
     * @author Administrator
     *
     */
    public class lockTest {
    
    	public static String obj1 = "obj1";
    	public static String obj2 = "obj2";
    
    	public static void main(String[] args) {
    		LockA la = new LockA();
    		new Thread(la).start();
    
    		LockB lb = new LockB();
    		new Thread(lb).start();
    	}
    
    }
    
    class LockA implements Runnable {
    
    	@Override
    	public void run() {
    		try {
    			System.out.println(new Date().toString() + "LockA开始执行");
    			while (true) {
    				synchronized (lockTest.obj1) {
    					System.out.println(new Date().toString() + " LockA 锁住 obj1");
    					Thread.sleep(2000);
    					synchronized (lockTest.obj2) {
    						System.out.println(new Date().toString() + " LockA 锁住 obj2");
    						Thread.sleep(60 * 1000); // 为测试,占用了就不放
    					}
    				}
    			}
    
    		} catch (Exception e) {
    			e.printStackTrace();
    		}
    	}
    
    }
    
    class LockB implements Runnable {
    
    	@Override
    	public void run() {
    		try {
    			System.out.println(new Date().toString() + "LockB开始执行");
    			while (true) {
    				synchronized (lockTest.obj2) {
    					System.out.println(new Date().toString() + " LockB 锁住 obj2");
    					Thread.sleep(2000);
    					synchronized (lockTest.obj1) {
    						System.out.println(new Date().toString() + " LockB 锁住 obj1");
    						Thread.sleep(60 * 1000); // 为测试,占用了就不放
    					}
    				}
    			}
    
    		} catch (Exception e) {
    			e.printStackTrace();
    		}
    	}
    
    }
    

      

    此时死锁产生。

     死锁解决办法:

          1.当几个线程都要访问共享资源A、B、C时,保证使每个线程都按照同样的顺序去访问它们,比如都先访问A,在访问B和C。 

          2.尽可能只一个对象,这样永远不会出现死锁情况

          3.

        

     

  • 相关阅读:
    log4net的使用
    在asp.net中使用 log4net 笔记
    JQuery插件开发
    使用Visual Studio宏来自动生成代码 [ Visual Studio | 宏 | 自动生成代码 ]
    如何在JBuilder 2006中打Jar包,并生成Exe文件
    如何更改java应用程序标题栏默认图标
    《ASP.NET AJAX程序设计》图书相关资源总索引
    Eclipse汉化的步骤,非常的详细
    家庭和睦、人生平淡也是一种成功
    程序员节诗词
  • 原文地址:https://www.cnblogs.com/clc2008/p/6759847.html
Copyright © 2011-2022 走看看