在java1.5之前,java在并发上面的建树不多,只提供了为数不多的方式来提供提高并发的效率。
其中synchronized关键字是使用最多的,这个看似简单的锁方式,效率奇差,所以那会,java程序员对于c++程序员的在java并发上的诟病总是无力回击。
在1.5之前,java提供的并发容器Vector,我们来看下具体的实现java.util.Vector
从中可以看出,Vector是把所有的方法前面的加上了synchronized关键字
在来看另外的一类静态方法,这类容器可以把List在包装一层,让后就可以作为并发的容器
仔细分析会发现
原来Collections.synchronizedList(List<T> list))这个方法最终会新建一个SynchronizedList<E>,它是继承自SynchronizedCollection<E>,来看SynchronizedList<E>的构造函数,
看看父类的详细的构成
怎样,是不是有一种恍然大悟的感觉,原来在构造函数里面弄了一个 Object mutx = this,让后所有的方法在调用的时候都synchronized(mutex)
相同的方法有
public static <T> Collection<T> synchronizedCollection(Collection<T> c)
public static <T> List<T> synchronizedList(List<T> list)
public static <K,V> Map<K,V> synchronizedMap(Map<K,V> m)
public static <T> Set<T> synchronizedSet(Set<T> s)
public static <K,V> SortedMap<K,V> synchronizedSortedMap(SortedMap<K,V> m)
public static <T> SortedSet<T> synchronizedSortedSet(SortedSet<T> s)