当前位置: 首页 > news >正文

b2c电子商务网站的特点网站设计公司网站制作

b2c电子商务网站的特点,网站设计公司网站制作,做网站php,四六级查成绩网站怎么做HashMap 线程安全性 线程不安全,无任何同步机制。多线程在读写情况下可能出现数据不一致的情况 底层结构 JDK 1.7及之前用的是数组加链表 JDK1.8 优化成了数组加链表加红黑树 当链表长度超过阈值就会转换成红黑树,提升查找效率。 null支持 允许…

HashMap

线程安全性

线程不安全,无任何同步机制。多线程在读写情况下可能出现数据不一致的情况 

底层结构

JDK 1.7及之前用的是数组加链表

JDK1.8 优化成了数组加链表加红黑树

当链表长度超过阈值就会转换成红黑树,提升查找效率。 

null支持

允许键和值都为null, 但是键只能有一个为null,注意HashMap的键具有唯一性;因为null的哈希值计算特殊,通常存储在数组的第一个位置附近。

性能

 单线程或者线程安全时,读写性能优秀。哈希算法可进行快速定位,链表或者红黑树处理冲突,平均的时间复杂度接近O(1)

HashTable

线程安全性

是线程安全的,通过给方法添加 synchronized 锁实现,因为给方法加锁的缘故,每个方法在同一时间只允许一个线程执行,虽然保证了数据的安全性,但在多线程的情况下性能较差。 

底层结构

 数据结构采用数组加链表的形式,通过哈希算法确定元素的位置,哈希冲突时用链表解决。

null支持

不允许键或值为null ,如果尝试插入null 会直接抛异常。HashTable 内部代码对 null 做了严格的检查。 

性能

多线程环境下,线程竞争锁激烈,读写性能低下;若单线程使用还有锁的开销不如直接用HashMap,基本已经被淘汰 

ConcurrentHashMap

线程安全性

是线程安全的,采用优化的锁策略, 跟HashTable 不同的是锁粒度更细,并发性能更高。

底层结构

JDK 1.7 也是数组加链表的形式,将数组元素分组去加锁;在JDK1.8 采用数组加链表加红黑树的形式,对每个数组元素加锁。通过CAS与锁保证多线程下的数据一致性。

null支持

不允许键或值为null,在多线程中,null可能会导致歧义,例如无法区分是初始化的null 还是插入的null。 

性能

 多线程并发读写性能优越,读操作几乎无锁,写操作锁粒度更细,减少了线程竞争,在高并发场景性能接近HashMap。

总结

名称HashMapHashTableConcurrentHashMap
线程安全性非线程安全线程安全线程安全
底层结构

JDK1.7数组+链表

JDK1.8数组+链表+红黑树

数组+链表

JDK1.7数组+链表

JDK1.8数组+链表+红黑树

null支持允许键值为null不允许键值为null不允许键值为null
性能单线程性能优,多线程不安全多线程性能差多线程性能优

http://www.cadmedia.cn/news/12326.html

相关文章:

  • 2008 iis 配置 asp网站短视频怎么赚钱
  • 邢台百姓网官网网站移动端优化工具
  • 如何查名下是否有注册的公司南京seo
  • 怎么查询建设通网站怎样推广app别人才愿意下载
  • 营销推广有哪些长春seo整站优化
  • 莱阳网站开发信息流广告投放工作内容
  • 目前网站建设采用什么技术东莞做一个企业网站
  • 杭州富阳网站建设公司全球搜索引擎
  • 中国城市建设官方网站学it需要什么学历基础
  • 五个网站创意营销新点子
  • 政府网站建设的理论平台推广方式方法是什么
  • 中国vpswindows野外农民工湖南seo服务
  • 专业做招聘的网站有哪些百度学术论文查重官网入口
  • 门户网站建设预算表高清视频网络服务器
  • 网站建设的3个基本原则百度权重批量查询
  • 成都高薪南网站建设seo技术网网
  • 个人网站设计背景图谷歌seo课程
  • 重庆知名商城网站建设公司沧州网站seo
  • 青秀区网站建设论文收录网站排名
  • 中山建设企业网站网站seo培训
  • 版式网站有哪些千锋教育培训机构可靠吗
  • 多城市分站站群cms郑州百度seo
  • 做好系部宣传和网站建设营销渠道模式有哪些
  • 做网站投诉要钱吗互联网产品运营推广方案
  • 网站建设是百度舆情监测平台
  • 衡阳北京网站建设爱站在线关键词挖掘
  • 网站设计开发收费标准推广普通话手抄报内容简短
  • 怎么呢搜到自己建设的网站东莞推广系统
  • 360客户如何做网站推广站长之家seo工具包
  • 德清网站公司建设外链官网