一、Lambda
jdk在1.8版本时引入了Lambda表达式,即函数式编程思想。
面向对象编程思想:做一件事情,找一个能解决这个事情的对象,调用对象的方法,完成事情
函数式编程思想:只要能获取到结果,谁去做的,怎么做的都不重要,重视的是结果,不重视过程。此思想强调的是做什么,而不是以什么形式做。
传统的使用Runnable匿名内部创建线程:
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("执行了啊");
}
}).start();
我们的目的是创建一个线程A,但为了达到创建的目的:
为了指定 run 的方法体,不得不需要 Runnable 接口的实现类;
为了省去定义一个 RunnableImpl 实现类的麻烦,不得不使用匿名内部类;
必须覆盖重写抽象 run 方法,所以方法名称、方法参数、方法返回值不得不再写一遍,且不能写错;
而实际上,似乎只有方法体才是关键所在。
引入Lambda后的写法:
new Thread(()->{System.out.println("执行了啊");}).start();
Lambda表达式的标准格式为:(参数类型 参数名称) ‐> { 代码语句 }
小括号内的语法与传统方法参数列表一致:无参数则留空;多个参数则用逗号分隔。
-> 是新引入的语法格式,代表指向动作。
大括号内的语法与传统方法体要求基本一致。
Lambda虽然语法很简洁,但是用起来的前提和限制还是比较多的:
- 使用Lambda必须具有接口,且要求接口中有且仅有一个抽象方法。 无论是JDK内置的 Runnable 、 Comparator 接口还是自定义的接口,只有当接口中的抽象方法存在且唯一 时,才可以使用Lambda。
- 使用Lambda必须具有上下文推断。 也就是方法的参数或局部变量类型必须为Lambda对应的接口类型,才能使用Lambda作为该接口的实例。
- 有且仅有一个抽象方法的接口(接口中的方法都是抽象方法),称为函数式接口
二、java中的堆内存和栈内存
java中的栈和堆怎么理解
Java把内存分为两种,一种是栈内存,一种是堆内存。
栈内存中存放一些基本类型的变量或者引用变量,堆内存用于存放new出来的对象或者数组。例如:
Student stu = new Student();
其中stu 就是引用变量,存放在栈内存中,new 创建出来的Studen() 存放在 堆内存中,整体来理解就是 栈内存中的 stu 变量 指向 堆内存中的 Studen() 变量。(这也就是java中的指针)