前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >线程安全的集合类(ConcurrentHashMap面试超高频考点)

线程安全的集合类(ConcurrentHashMap面试超高频考点)

作者头像
终有救赎
发布2023-10-16 10:09:08
1280
发布2023-10-16 10:09:08
举报
文章被收录于专栏:多线程

🧵多线程环境下使用ArrayList

✨自己使用同步机制synchronized或者ReentrantLock

🎉使用Collections.synchronizedList(new ArrayList); synchronizedList是标准库提供的一个基于synchronized进行线程同步的List,synchronizedList的关键操作上都带有synchronized来满足线程安全

🎊使用CopyOnWriteArrayList CopyOnWrite容器即写时复制容器: 当往一个容器中添加元素的时候,不往该容器中直接添加元素,而是先将该容器进行复制一个新的容器,添加的时候往复制的容器中添加 添加完后,将原容器中的引用指向新复制的容器 CopyOnWrite容器是一种读和写分离的思想,读和写的容器是不同的

优点:在读多写少的情况下,性能高

缺点:占有内存多,新写的数据不能被第一时间读到

🎡多线程环境下使用队列(Queue)

使用阻塞队列

🥎ArrayBlockingQueue,基于数组实现的阻塞队列 🏀LinkedBlockingQueue,基于链表实现的阻塞队列 🏐PriorityBlockingQueue,基于堆实现的带优先级的阻塞队列 ⚽TransferQueue,最多只包含一个元素的阻塞队列

🎑多线程环境下使用哈希表(面试超高频考点)

HashMap是线程不安全的,在多线程下使用线程安全的哈希表可以使用: 🎺HashTable 🪗ConcurrentHashMap

🏅HashTable

HashTable的底层实现只是对关键方法加上synchronized HahTable的底层数据结构为数组+链表

image.png
image.png

这样加锁相当于对HashTable对象本身加锁即对整个数组加锁,将整个数组锁住了,如果多个线程同时访问同一个HashTable对象,就会出现竞争锁,造成锁冲突 缺点: 因为方法加上了锁,所以每次使用的时候都要获取锁,释放锁,性能效率比较低下

🎖️ConcurrentHashMap

底层数据结构为数组+链表+红黑树,红黑树会和链表在某种条件下互相发生转换

⁉️关于ConcurrentHashMap如何实现线程安全:

⏰对于读操作,因为读操作本身就为线程安全的,对于ConcurrentHashMap的属性使用了volatile关键字修饰,确保每次读的值为主存中的最新值 ⏲️对于写操作,写操作仍然使用synchronized加锁,但是锁的不是整个数组,如果数组中是链表,锁头结点,如果数组中是红黑树,锁根节点,这样大大降低了锁冲突发生的概率,即多个线程操作不同的结点还是并发并行执行的,操作同一个结点才是互斥的 🕰️充分利用CAS特性,如果结点为空,CAS+自旋,如果结点有元素,synchronized(头节点),size属性也是通过CAS来更新的,这样避免出现重量级锁的情况

🎃对于扩容操作:

⚽需要创建一个新数组,线程发现需要扩容,就搬几个元素到新数组 🏐新老数组是同时存在的 🏀后续的线程也会参与搬几个元素到新数组的过程 🥎待老数组的所有元素都搬完删除老数组 🏉对于扩容的操作,插入只往新数组中插查找需要同时查找新数组和老数组

🎯面试题:HashTable,HashMap,ConcurrentHashMap的区别?

🕐HashMap,线程不安全,key允许为null 🕑HashTable,线程安全,使用synchronized锁整个HashTable对象,效率低,key不允许为null 🕒ConcurrentHashMap,线程安全,对于属性使用了volatile关键字,使用synchronized锁每个链表的头结点降低锁冲突的发生率,充分利用了CAS特性,优化扩容方式,key不允许为null

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-10-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 🧵多线程环境下使用ArrayList
  • 🎡多线程环境下使用队列(Queue)
  • 🎑多线程环境下使用哈希表(面试超高频考点)
    • 🏅HashTable
      • 🎖️ConcurrentHashMap
        • 🎯面试题:HashTable,HashMap,ConcurrentHashMap的区别?
        相关产品与服务
        容器服务
        腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档