并发编程:同步类容器

        同步类容器:一种容器,一种注重同步的容器,如Vector,HashTable等容器。同步类容器都是线程安全的,某些情况下还需要加锁来保护复合操作(复合操作,如迭代、跳转、条件运算等),因为这些复合操作在多线程并发地修改容器时,可能会表现出意外的行为(比如经典的ConcurrentModificationException异常)。

        传统的同步类容器,其同步功能基本都是由JDK的Collections.synchronized...等工厂方法去创建实现的(JDK1.5及以前的版本),其底层的机制也即是由synchronized关键字对每个公用的方法进行同步,使得每次只能有一个线程访问容器的状态。

Collections.synchronizedXX方法:

    //同步类容器
    Map<String,String> strMap = Collections.synchronizedMap(new HashMap<String,String>());    
    //Collections.synchronizedCollection(c);
	//Collections.synchronizedList(list)
	//Collections.synchronizedMap(m)
	//Collections.synchronizedNavigableMap(m)
	//Collections.synchronizedNavigableSet(s)
	//Collections.synchronizedSet(s)
	//Collections.synchronizedSortedMap(m)
	//Collections.synchronizedSortedSet(s)

下面给出一个同步类容器的小例子:

public class 容器的synchronizedX方法 {
	public static void main(String[] args) {
		final List<String> strList = new LinkedList<String>();																	    //普通的容器
		//初始化strList
		for(int index=0;index<1000;index++)			strList.add("赵"+index);
		//多个线程开始操作
		for(int i = 1;i < 9;i++) {
			new Thread("线程"+i) {
				public void run() {
					while(true) {
						if(strList.isEmpty()) break;
						System.err.println(Thread.currentThread().getName()+"----"+strList.remove(0));
					}
				}
			}.start();
		}
		System.err.println("每次只有一个线程访问-->避免出现多个线程同时对同一资源操作的异常");
	}
}

猜你喜欢

转载自blog.csdn.net/txd2016_5_11/article/details/83188290