线程安全的同步容器 及并发容器

java 中常见的线程不安全类:

StringBuilder----加了synchronized--- > StringBuffer(安全的)

 

SimpleDateFormat-----------------------------JodaTime(安全的)

 

ArrayList,HashSet,HashMap

 

一、线程安全--同步容器

 

ArrayList-->Vector,stack

HashMap-->HashTable

Collcetions.synchronizedXXX(list,Set,Map)

 

注意:在Vector遍历的时候 用foreach 和迭代器 都会抛出java.util.ConcurrentModificationException

final void checkForComodification() {

if (modCount != expectedModCount)

throw new ConcurrentModificationException();

}

解决方案:在遍历的时候不要进行删除或添加操作,如果一定要,可以在遍历的时候吧需要操作的数据记录下来再进行操作

二、线程安全--并发容器

 

ArrayList--->CopyOnWriteArrayList 更适合读多写少的操作

HashSet-->CopyOnWriteArraySet

TreeSet--->ConcurrentSkipListSet :在批量操作时,执行 addAll(),removeAll()等方法是不能完全保证原子性,还是调用底层的addAll(),等方法

 

 

**HashMap--->ConCurrentHashMap

TreeMap--->ConCurrentSkipListMap

有人做过实验,在四个线程,1.6万的数据ConCurrentHashMap 存取速度大约是ConCurrentSkipListMap 四倍左右

优点:1、ConCurrentSkipListMap key是有序的

2、ConCurrentSkipListMap 支持更高的并发,也就是说,数据量一定,线程的并发数越多,越能体现出优势

 

 

总结:安全共享对象策略(不可变对象,线程封闭,同步容器及并发容器)

1、线程限制:一个被线程限制的对象,由线程独占,并且只能被占有他的线程修改。

2、共享只读:一个共享只读的对象,在没有额外同步的情况下,可以被多个线程并发访问,但是任何线程都不能修改它。

3、线程安全对象:一个线程安全的对象或者容器,在内部通过同步机制来保证线程安全,所以其他线程无需额外的同步就可以通过公共接口随意的访问它。

4、被守护对象:被守护的对象只能通过获取特定的锁来访问

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值