一、版本中数据结构的修改浅析
1、HashMap、HashSet、ConcurrentHashMap的数据结构发生变化

(1)HashMap简介(结构:哈希表+链表)

HashMap存储的数据是无序的,结构哈希表加链表的存储方式,key不能重复,哈希表就是数组,存储的数组都是entry,初始大小默认是16,HashMap底层使用哈希算法原理:当创建一个对象,想要加入到HashMap,会默认调用底层的一个方法hashCode()。

HashMap算出索引值,会上对应的链表中找是否有对象,如果没有对象,没有直接添加,如果有对象,通过equals比较两个对象,如果内容一样,将视为重复元素,后边的将前边的覆盖掉.内容不一样,JDK1.7中,不一样的时候生成一个链表,后加入的跟前边的生成链表,称为"碰撞","碰撞"过多的时候,下次添加就会更多个值进行equals,效率会极低.如何避免?无法避免。
         如果不采用上述方式,就需要每次添加都equals比较,并且还要比较下一次添加的值,效率会大大降低。

         HashMap具有加载因子,是0.75,当哈希表达到75%的时候,就会进行扩容,扩容是原来长度的2倍.一旦扩容,发生碰撞的元素就会进行重新排序.将元素放到新的位置上去,以解决"碰撞"问题.
         HashMap把Key和Value封装到entry对象中,还是无法避免碰撞问题。
  (2)Java8中HashMap的数据结构发生变化(结构:数组+链表+红黑树)

新版设计:

            当HashMap中的某一个链表的长度大于8,并且元素总容量大于64的时候,链表就会变为二叉树中的红黑树.
         优势:除了添加,其他的效率都提高了.1.8前添加的重复元素直接添加在链表最后,1.8中需要跟红黑树的子节点进行比较,最后找到合理的位置添加.

  查询提速,原来是遍历整个链表,挨个比较查询值.
        现在二叉树节点比较查询,查询的节点数目减少。
  (3)HashSet也会更新,因为HashSet的底层就是HashMap。
  (4)ConcurrentHashMap简述
         锁分段(锁分离)机制1.8以前

  也进行了更改,以往HashMap线程不安全的处理方案是加锁,但是效率极低,1.8以前,它有个默认并发级别是16,每个段都是线程安全的,在每个段中对应着一个HashMap,意味着一次能有16个线程访问HashMap.
         无锁算法1.8以后
     1.8前存在问题:并发级别段的大小不好控制,过大浪费资源,过小操作不便.
     1.8中取消了并发级别段,采用了CAS算法,其实是一个底层硬件的算法,底层硬件对于并发的一个支持,效率比锁的高,CAS算法又称为无锁算法。
  (5)JVM支持的内存结构发生改变
          JVM拥有两块虚拟的内存空间,一部分称之为栈,一部分称之为堆.还有一部分为方法区.

          方法区是属于堆内存的,堆内存分为垃圾回收区和永久区,方法区属于永久区的一部分.
         JVM分类(不同厂商):
                Oracle-Sun Hotspot 
                Oracle(自己生产的) JRocket
                IBM   J9
                Alibaba(国产) Taobao
         1.8以前只有Hotspot的版本有永久区,其他厂商独立分区.(永久区存储类加载信息)
         1.8以后JVM变化:

              1.8中删除了JVm中的永久区.独立分出一片区域叫做MetaSpace(元空间),元空间采用物理内存,服务器内存空间多大,MetaSpace就有多大.OOM错误发生概率降低.(除非一个无限创建的类加载),由于垃圾回收机制改为元空间将要满的时候才垃圾回收,垃圾回收运行的次数减少了,效率提高了.
              永久区中调优属性PermGenSize和MaxPermGenSize,改为MetaSpaceSize和MaxMetaSpaceSize

注:

哈希算法:

哈希算法是将hashCode()生成的值,进行一个运算(哈希算法运算),运算成对应的数组的索引值,这就是哈希算法.

JAVA 8 主要新特性 ----------------(二)版本中数据结构的修改浅析的更多相关文章

  1. JAVA 8 主要新特性 ----------------(二)JDK1.8优点概括

    一.JDK1.8优点概括 1.速度更快 由于底层结构和JVM的改变,使得JDK1.8的速度提高. 2.代码更少(增加了新的语法 Lambda 表达式)          增加新特性Lambda表达式的 ...

  2. 深入理解java虚拟机---jdk8新特性(二)

    1.jdk8新特性 1.新特性 2.lambda函数表达式的作用 A: 替换内部类 B:对集合的操作并行化

  3. JAVA 8 主要新特性 ----------------(一)总纲

    一.版本中数据结构的修改浅析 二.JDK1.8优点概括 三.新功能Lambda表达式入门 四.Lambda函数式接口 五.Lambda方法引用与构造器引用 六.集合Stream API 七.新时间日期 ...

  4. [转] Java 8的新特性

    简介 毫无疑问,Java 8是Java自Java 5(发布于2004年)之后的最重要的版本.这个版本包含语言.编译器.库.工具和JVM等方面的十多个新特性.在本文中我们将学习这些新特性,并用实际的例子 ...

  5. Java 8的新特性—终极版

    作者:杜琪[译] 原文链接:http://www.jianshu.com/p/5b800057f2d8 1. 简介 毫无疑问,Java 8是Java自Java 5(发布于2004年)之后的最重要的版本 ...

  6. Java 9和Java 10的新特性

    http://www.infoq.com/cn/news/2014/09/java9 Java 9新特性汇总 继2014年3月份Java 8发布之后,Open JDK加快了开发速度, Java 9的发 ...

  7. JDK 15 JAVA 15的新特性展望

    目录 JEP 371: Hidden Classes JEP 372: 删除 Nashorn JavaScript Engine JEP 377: 新的垃圾回收器ZGC正式上线了 JEP 378: T ...

  8. Java8新特性(一)_interface中的static方法和default方法

    什么要单独写个Java8新特性,一个原因是我目前所在的公司用的是jdk8,并且框架中用了大量的Java8的新特性,如上篇文章写到的stream方法进行过滤map集合.stream方法就是接口Colle ...

  9. [转] Java se 7新特性研究(二)

    详见: http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp82   今天主要研究Java se 7中异常处理的新功能.从今天开始正在 ...

随机推荐

  1. [SQL]sql server中如何直接查询存储过程EXEC返回的结果集?

    Declare @T Table (iDay VARCHAR(),iNum DECIMAL(,),yuxiang DECIMAL(,)) Insert @T --EXEC [dbo].[BSP0101 ...

  2. [NOI2011]智能车比赛 (计算几何 DAG)

    /* 可以发现, 最优路径上的所有拐点, 基本上都满足一定的性质, 也就是说是在矩形上的拐角处 所以我们可以把他们提出来, 单独判断即可 由于我们提出来的不超过2n + 2个点, 我们将其按照x坐标排 ...

  3. day37协程与线程套接字通讯

    协程与线程套接字通讯基于多线程实现套接字服务端支持并发,服务端 from socket import * from threading import Thread def comunicate(con ...

  4. Oracle 唯一 约束(unique constraint) 与 索引(index) 关系说明

    一. 官网对Unique Constraints说明 http://download.oracle.com/docs/cd/E11882_01/server.112/e16508/datainte.h ...

  5. 5种必会的Java异步调用转同步的方法你会几种

    转载请注明本文地址:https://www.jianshu.com/p/f00aa6f66281 源码地址:https://gitee.com/sunnymore/asyncToSync Sunny先 ...

  6. Android向系统日历中添加日程事件

    转自Android向系统日历中添加日程事件 总结 在项目开发中,我们有预约提醒.定时提醒需求时,可以使用系统日历来辅助提醒: 通过向系统日历中写入事件.设置提醒方式(闹钟),实现到时间自动提醒的功能: ...

  7. log4j配置后行号乱码显示为?问号

    debug="true"  classpathref="accrual.path" > 首发于 http://blog.xfuse.cn 参考文档 htt ...

  8. Mac 笔记本 开发日记

    1.录屏,截图 Mac 自带录屏功能 command +control +o 2.复制当前应用,在启一个当前app窗口 command+n 3.快速回到桌面 command +f3 4.选中文件,复制 ...

  9. source tree使用经验

    FeatureXXX具体功能开发分支,从develop分支拉,功能开发自测完后合并到develop分支.来不及上线的feature分支不要合并到develop. develop开发分支,上面代码都是已 ...

  10. Android Studio模拟器磁盘空间不足(Not enough disk space to run AVD)

    在Android Studio中运行模拟器时,提示Error: Not enough disk space to run AVD '....'. Exiting.是说安装模拟的磁盘空间不足,导致无法运 ...