在java的多线程同步互斥处理中,synchronized是别不可少的东西.
但是如果不清晰的编程的话,也就是乱用synchronized的话,死锁的发生就是离你很近的话题了.
在前面的一个维护中就发现一个死锁的bug.究其原因是开发者没有真正明白多线程的同步互斥,没有意识到死锁的发生,或者说自己认为写的代码不会发生死锁.
死锁的发生一般并不是很容易再现的.一旦发生了调查,确认都会花费很多时间.特别是对大型网站来时这种现象的发生时不可原谅的.
互斥处理中锁方法和锁块. 感觉是在锁块的处理中容易乱用synchronized.
在那个维护的中的代码逻辑:
方法A中的如下的处理
准备处理的代码1
synchronized (this) {
处理1
}
准备处理的代码2
synchronized (this) {
处理2
}
其他处理
这样用一个方法中把自己这个对象锁了两次.死锁的发生就是有可能的了.
在上面的那个问题代码中,如果是锁自己的话,在一个方法中就不能进行多次锁.
其他的多线程还有很多很多需要的注意的,上面只是就事论事简单说了一下碰到的问题.