java.util.vector 多线程有关问题及java.util.concurrent包下并发安全原理

java.util.vector 多线程问题及java.util.concurrent包下并发安全原理

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包。java.uitl.concurrent包下的并发集合就没有上述问题存在。因为包下的集合使用了读写锁。(读写锁位于concurrent.lock子包下)。

 

 

写的比较简单,有问题请指正--