java中哪些集合是线程安全的,哪些是线程不安全的

目录
1. 常见集合
2.什么叫“集合是线程不安全的”
3. 线程安全和线程不安全的集合
4. 如何综合考虑线程不安全和效率低的问题



1. 常见集合
这里自己总结了一些比较常见的java集合,对于这些集合的特点和区别后期博客中会进行总结介绍:

2.什么叫“集合是线程不安全的”
首先我们来了解一下什么叫集合是线程不安全的:

当多个并发同时对非线程安全的集合进行增删改的时候会破坏这些集合的数据完整性;
例如:当多个线程访问同一个集合或Map时,如果有超过一个线程修改了ArrayList集合,则程序必须手动保证该集合的同步性。

3. 线程安全和线程不安全的集合
Vector、HashTable、Properties是线程安全的;

ArrayList、LinkedList、HashSet、TreeSet、HashMap、TreeMap等都是线程不安全的。

值得注意的是:为了保证集合是线程安全的,相应的效率也比较低;线程不安全的集合效率相对会高一些。

4. 如何综合考虑线程不安全和效率低的问题
为了保证集合既是安全的而且效率高,Collections为我们提出了解决方案,把这些集合包装成线程安全的集合。
Collections提供了如下几个静态方法。

1 <T> Collection<T> synchronizedCollection(Collection<T> c); //返回指定collection 对应的线程安全的collection。
2 static <T> List<T> synchronizedList(List<T> list); //返回指定List对象对应的线程安全的List 对象。
3 static <K, V> Map<K, V> synchronizedMap(Map<K, V> m); //返回指定Map对象对应的线程安全的Map对象。
4 static <T> Set<T> synchronizedSet(Set<T> s); //返回指定Set对象对应的线程安全的Set对象。
5 static <K, V> SortedMap<K, V> synchronizedSortedMap(SortedMap<K, V> m); //返回指定SortedMap对象对应的线程安全的SortedMap对象。

当然,在实际工作中,公司都会自己封装一些线程安全且效率高的集合。
————————————————
版权声明:本文为CSDN博主「城序猿」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_43374508/java/article/details/90024426

原文地址:https://www.cnblogs.com/aaaazzzz/p/12793428.html