package endual;
import java.util.Iterator;
import java.util.List;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.concurrent.CopyOnWriteArraySet;
public class TestMian {
public void main() {
ConcurrentMap map = new ConcurrentHashMap() ;
map.put(1, 1) ;
map.put(2, 2) ;
map.put(3, 3) ;
System.out.println("=====" + map.size());
for (int i=0; i < map.size(); i++) {
//System.out.println(i);
System.out.println(map.get(i)) ;
//System.out.println(ma);
}//end for
List lists = new CopyOnWriteArrayList() ; //实现的是的list的借口
CopyOnWriteArraySet sets = new CopyOnWriteArraySet() ; // 内部实现的是CopyOnWriteArrayList
//sets.add(e) ;
//set集合类和其他的集合类不一样的地方是循环取得set里面的数据的时候
//用到其他的迭代类代替,这可能是它的实现是是有其他其他的集合类实现也有关系的
Iterator iii = sets.iterator() ;
iii.hasNext() ;
iii.next() ;
}
}
其他在并发访问的时候,并不是vetor和hastTable都是线程安全的,虽然加了syn的同步关键词。
但是如果我用跨线程的访问并且操作数据就会出现错误了。