1、vector在所有的方法上都加上了synchronized关键字,这样保证了访问vector对象的任何方法时都必须获取对象锁,所以vector保证了不会被多线程同时访问,但是如果我的某个方法这样写:
//vector 是全局变量
public boolean putIfAbsent() {
boolean absent = vector.contains(x);
if (absent) {
vector.add(x);
}
return absent;
}
在contains方法判断为真之后,线程释放锁,这时在add方法被调用之前是有空隙的,其他线程完全有可能获取锁并改变vector的状态,也只有那个线程释放锁之后,add方法才会被调用。这样就产生了并发问题。
2、以上说的只是其中一种问题,java1.5推出的java.uitl.concurrent包,就是为了解决复杂的并发问题的。
写的比较简单,有问题请指正--