栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

每天学一个面试题(3)(高并发中的集合有那些问题?)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

每天学一个面试题(3)(高并发中的集合有那些问题?)

问题:高并发中的集合有那些问题?

难度:★★★★

工资提升度:★★☆

(★:表示一星   ☆:表示半颗星)

博主精选答案: 第一代线程安全集合类:Vector、Hashtable

是怎么保证线程安排的:使用synchronized修饰方法缺点:效率低下


第二代线程非安全集合类:ArrayList、HashMap

线程不安全,但是性能好,用来替代Vector、Hashtable
使用ArrayList、HashMap,需要线程安全怎么办呢?
使用Collections.synchronizedList(list); Collections.synchronizedMap(m);
底层使用synchronized代码块锁虽然也是锁住了所有的代码,但是锁在方法里边,并所在方法外边性能可以理解为稍有提高吧。毕竟进方法本身就要分配资源的


第三代线程安全集合类

在大量并发情况下如何提高集合的效率和安全呢?
java.util.concurrent.*
ConcurrentHashMap:copyOnWriteArrayList :
CopyonWriteArraySet:    注意不是CopyOnWriteHashSet*
底层大都采用Lock锁(1.8的ConcurrentHashMap不使用Lock锁),保证安全的同时,性能也很高。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/873858.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号