加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java 8 jdk1.8 新特性

发布时间:2020-12-15 07:55:13 所属栏目:Java 来源:网络整理
导读:1Lambda表达式 2函数式接口 函数式接口(Functional Interface)就是一个有且仅有一个抽象方法,但是可以有多个非抽象方法的接口。 java 8为函数式接口引入了一个新注解@FunctionalInterface 3default关键字 接口可以有实现方法 用default关键字修饰 4方法与构

1Lambda表达式

2函数式接口

函数式接口(Functional Interface)就是一个有且仅有一个抽象方法,但是可以有多个非抽象方法的接口。
java 8为函数式接口引入了一个新注解@FunctionalInterface

3default关键字

接口可以有实现方法 用default关键字修饰

4方法与构造函数引用

  1. 对象::实例方法名
  2. 类::静态方法名
    为了让lambda表达式更加精简

5Date Api更新  

1.8之前JDK自带的日期处理类非常不方便,我们处理的时候经常是使用的第三方工具包,比如commons-lang包等。不过1.8出现之后这个改观了很多,比如日期时间的创建、比较、调整、格式化、时间间隔等。这些类都在java.time包下。比原来实用了很多。

6 流

高级迭代器

7 map实现 加入红黑树

+红黑树 (详细见?hashmap源码分析)-----------更快速
?

在jdk1.8中对hashMap等map集合的数据结构优化。 原来的hashMap采用的数据结构是哈希表(数组+链表),hashMap默认大小是16,一个0-15索引的数组,如何往里面存储元素,首先调用元素的hashcode方法,计算出哈希码值,经过哈希算法算成数组的索引值,如果对应的索引处没有元素,直接存放,如果有对象在,那么比较它们的equals方法比较内容? 如果内容一样,后一个value会将前一个value的值覆盖,如果不一样,在1.7的时候,后加的放在前面,形成一个链表,形成了碰撞,在某些情况下如果链表?无限下去,那么效率极低,碰撞是避免不了的? 加载因子:0.75,数组扩容,达到总容量的75%,就进行扩容,但是无法避免碰撞的情况发生? 在1.8之后,在数组+链表+红黑树来实现hashmap,当碰撞的元素个数大于8时 & 总容量大于64,会有红黑树的引入? 除了添加之后,效率都比链表高,1.8之后链表新进元素加到末尾? ConcurrentHashMap (锁分段机制),concurrentLevel,jdk1.8采用CAS算法(无锁算法,不再使用锁分段),数组+链表中也引入了红黑树的使用

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读