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包,就是为了解决复杂的并发问题的。
写的比较简单,有问题请指正--
本文探讨了在使用Vector类时出现的并发问题,并详细解释了如何通过Java 1.5引入的concurrent包来解决复杂的并发问题。重点讨论了在多线程环境下确保数据一致性和线程安全的方法。
1228

被折叠的 条评论
为什么被折叠?



