java8的新特性之一:
1.1
底层数据结构的改变:主要体现在hashmap集合的改变。当hashmap中链表的长度超过8,总
容量超过64时,链表会转化为红黑树的数据结构类型。减少我们在链表出现多个碰撞时的查询
添加元素的时间。首先我们来说说hashmap,当我们put一个元素的时候,该元素通过
hashcode()方法生成一个hash码,对该hash码进行hash算法的运算生成一个数组的索引下标。
判断该位置有没有元素,没有则直接放入,有的话则通过equals()比较是否是覆盖相同元素,
相同则进行覆盖,不相同则以链表的形式放到链尾。hashmap的默认大小是16,原因在我分析有
这么几个方便,第一:hashmap的扩容大小指定了是2的n次方。第二:在我们不指定集合大小的
时候,16是一个即不浪费内存空间,同时又能减少hashmap碰撞的一个合理值。第三:减少因初始值
太小造成的频繁扩容。同时concurrentHashmap的数据结构也发生了该表。变成了数组+链表+红黑树
的结构类型。这里有一点要说的就是concurrentHashmap由之前的并发控制机制变成cas算法。提高
了效率。
1.2
在内存结构方便了也发生了改变,内存区由原来的栈,堆(永久区),方法区变为栈,堆,
元空间(加载类信息的地方)。jvm的一些参数也发生了改变。
2.1
lambda表达式,这是java8在语法上的一个新特点。左边一般是写传入的参数,右边写实现的
功能代码。格式如下 (x) -> return System.out.print(x)。如果lambda体只有一条语
句,return也可以省略。
lambda提供了四大核心内置函数式接口。
先介绍下函数式接口的概念:
只有一个抽象方法的接口,不过需要注意的是可以有多个默认方法。
1.消费型接口:Consumer { void accept(T)}
2.供给型接口:Supplier { T get()}
3.函数型接口: Function<T,R> { R apply(T)}
4.断言型接口:Predicate {Boolean test(T)}。
其中还有很多类型的子接口。带多个参数,不同类型的参数的子接口,比BiFunction<T,U,R> {R apply(T,U)},intFunction { R apply(int)}。
2.2
lambda表达式还可以以更简洁的方式去书写。我们可以通过方法引用,构造器引用,数组引用的
方式去书写lambda表达式,它是lamada的另一种表现形式。
方法引用的三种类型(如果lambda体中的方法在其他地方已经完成过了以后,就可以直接通过方法引用的方式去实现)
1、对象::实例方法
PrintStream ps = System.out;
Consumer con = (x) -> ps.print(x);
Consumer con2 = ps::print;
con2.accpt(“aaa”);
2、类名::静态方法
Comparator com = (x,y) -> Integer.compare(x,y);
Comparatot com2 = Integer::compare;
3、类名::实例方法
(如果lambda体中参数列表的第一个参数是调用方法的参数,第二个参数是方法中的参数,那么就可以通过类名::实例方法的形式去书写lambda表达式)
BiPredicate<String,String> bp = (x,y) -> x.equals(y);
BiPredicate<String,String> bp = String::equals;
另外还有构造器引用,和数组引用,使用方法和方法引用类似,就不赘述了。