1 死锁是什么

 死锁是指两个线程之间相互等待对方资源,但同时又互不相让,都想自己先执行

2 Java中的死锁具体例子

  使用synchronized 关键子作为锁,并且两个线程之间同时对同一个synchronized关键子修饰的对象锁进行争抢,导致死锁

  具体代码

  

public class MayDeadLock {
 
    Object o1 = new Object();
    Object o2 = new Object();
 
    public void thread1() throws InterruptedException {
        synchronized (o1) {
            Thread.sleep(500);
            synchronized (o2) {
                System.out.println("线程1成功拿到两把锁");
           }
        }
    }
 
    public void thread2() throws InterruptedException {
        synchronized (o2) {
            Thread.sleep(500);
            synchronized (o1) {
                System.out.println("线程2成功拿到两把锁");
            }
        }
    }
 
    public static void main(String[] args) {
        MayDeadLock mayDeadLock = new MayDeadLock();
        new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    mayDeadLock.thread1();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }).start();
        new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    mayDeadLock.thread2();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }).start();
    }
}

首先,代码中创建了两个 Object 作为 synchronized 锁的对象,线程 1 先获取 o1 锁,sleep(500) 之后,获取 o2 锁;线程 2 与线程 1 执行顺序相反,先获取 o2 锁,sleep(500) 之后,获取 o1 锁。 假设两个线程几乎同时进入休息,休息完后,线程 1 想获取 o2 锁,线程 2 想获取 o1 锁,这时便发生了死锁,两个线程不主动调和,也不主动退出,就这样死死地等待对方先释放资源,导致程序得不到任何结果也不能停止运行。

3 数据库中死锁的例子

   数据库的死锁主要发生在事务与事务之间

  数据库死锁是指两个或者多个事务在同一资源相互占用,并请求锁定对方占用的资源,从而导致恶行循环的现象,当多个事务试图以不同的顺序锁定资源时,就可能产生死锁。多个事务同时锁定一个资源时

  也会产生死锁,例如,设想下面两个事务同时处理StockPrice表

事务1

start transaction;

update stockPrice set close = 45 where id =1;

update stockPrice set close = 46 where id =2;

commit;


事务2 

start transaction;

update stockPrice set close = 47  where id =2;

update stockPrice set close = 48  where id =1;

commit;

  如果凑巧,两个事务都执行了第一条update语句,更新了一行数据,同时也锁定了该行数据,接着每个事务都尝试去执行第二条 update语句,却发现该行已经被对方当锁定,然后两个事务都在等待对方释      放锁,同时又持有对方需要的锁,则陷入死循环。死锁    产生