java死锁业务场景,死锁讲解并以数据库死锁和java死锁进行具体场景讲解

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语句,却发现该行已经被对方当锁定,然后两个事务都在等待对方释      放锁,同时又持有对方需要的锁,则陷入死循环。死锁    产生

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值