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子包下)。
写的比较简单,有问题请指正--