java线程同步互斥_java的多线程同步互斥:synchronized的乱用

在java的多线程同步互斥处理中,synchronized是别不可少的东西.

但是如果不清晰的编程的话,也就是乱用synchronized的话,死锁的发生就是离你很近的话题了.

在前面的一个维护中就发现一个死锁的bug.究其原因是开发者没有真正明白多线程的同步互斥,没有意识到死锁的发生,或者说自己认为写的代码不会发生死锁.

死锁的发生一般并不是很容易再现的.一旦发生了调查,确认都会花费很多时间.特别是对大型网站来时这种现象的发生时不可原谅的.

互斥处理中锁方法和锁块. 感觉是在锁块的处理中容易乱用synchronized.

在那个维护的中的代码逻辑:

方法A中的如下的处理

准备处理的代码1

synchronized (this) {

处理1

}

准备处理的代码2

synchronized (this) {

处理2

}

其他处理

这样用一个方法中把自己这个对象锁了两次.死锁的发生就是有可能的了.

在上面的那个问题代码中,如果是锁自己的话,在一个方法中就不能进行多次锁.

其他的多线程还有很多很多需要的注意的,上面只是就事论事简单说了一下碰到的问题.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值