- 函数式编程思想
面向对象的思想:
做一件事情,找一个能解决这个事情的对象,调用对象的方法,完成事情。
函数式编程思想:
只要能获取到结果,谁去做的,怎么做的不重要,重视的是结果,不重视过程。 - 冗余的Runnable代码
package Runnable;
/*
使用实现Runnable接口的方式实现多线程程序
*/
public class Demo01Runnable {
public static void main(String[] args) {
//创建Runnable接口的实现类对象
RunnableImpl run = new RunnableImpl();
//创建Thread类对象,构造方法中传递Runnable接口的实现类
Thread t = new Thread(run);
//调用start方法开启新线程,执行run方法
t.start();
//简化代码,使用匿名内部类,实现多线程程序
Runnable r = new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + "新线程创建了");
}
};
new Thread(r).start();
//继续简化代码
new Thread(new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + "新线程创建了");
}
}).start();
}
}
实现类
package Runnable;
/*
创建Runnable接口的实现类,重写run方法,设置线程任务
*/
public class RunnableImpl implements Runnable{
@Override
public void run() {
System.out.println(Thread.currentThread().getName()+"新线程创建了");
}
}
- Lambda表达式更优写法
package Runnable;
public class Demo02Lambda {
public static void main(String[] args) {
//使用匿名内部类的方式,实现多线程
new Thread(new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + "新线程创建了");
}
}).start();
//使用Lambda表达式,实现多线程
new Thread(() ->{
System.out.println(Thread.currentThread().getName() + "新线程创建了");
}
).start();
}
}
- Lambda表达式的标准格式
Lambda表达式标志格式:
由三部分组成:
a.一些参数
b.一个箭头
c.一段代码
格式:
(参数列表)->{重写方法的代码};
解释说明格式:
():接口中抽象方法的参数列表,没有参数,就空着,有参数就写出参数,多个参数使用逗号分隔
->:传递的意思,把参数传递给方法体{}
{}:重写接口的抽象方法方法体
package Runnable;
/*
Lambda表达式标志格式:
由三部分组成:
a.一些参数
b.一个箭头
c.一段代码
格式:
(参数列表)->{重写方法的代码};
解释说明格式:
():接口中抽象方法的参数列表,没有参数,就空着,有参数就写出参数,多个参数使用逗号分隔
->:传递的意思,把参数传递给方法体{}
{}:重写接口的抽象方法方法体
*/
public class Demo02Lambda {
public static void main(String[] args) {
//使用匿名内部类的方式,实现多线程
new Thread(new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + "新线程创建了");
}
}).start();
//使用Lambda表达式,实现多线程
new Thread(() ->{
System.out.println(Thread.currentThread().getName() + "新线程创建了");
}
).start();
}
}
- Lambda表达式的练习(无参数无返回)
Demo01Cook类
package LambdaTest1;
/*
需求:
给定一个厨子Cook接口,内含唯一的抽象方法makeFood,且无参数,无返回值。
使用Lambda的标准格式调用invokeCook方法,打印输出“吃饭了!”字样。
*/
public class Demo01Cook {
public static void main(String[] args) {
//调用invokeCook方法,参数是Cook接口,传递Cook接口的匿名内部类对象
invokeCook(new Cook() {
@Override
public void makeFood() {
System.out.println("吃饭了!");
}
});
//使用Lambda表达式简化匿名内部类的书写
invokeCook(()->{
System.out.println("吃饭了!");
});
}
//定义一个方法,参数传递Cook接口,方法内部调用Cook接口中的方法makeFood
public static void invokeCook(Cook cook){
cook.makeFood();
}
}
接口
package LambdaTest1;
public interface Cook {
//定义无参数,无返回值的方法makeFood
public abstract void makeFood();
}
Demo02
package LambdaTestHaveParameterHaveReturn;
import java.util.Arrays;
import java.util.Comparator;
/*
Lambda表达式有参数有返回练习
需求:
使用数组存储多个Person对象
对数组中的Person对象使用Arrays的sort方法通过年龄进行升序排序
*/
public class Demo01Arrays {
public static void main(String[] args) {
//创建数组
Person[] arr = {
new Person("柳岩", 38),
new Person("迪丽热巴", 18),
new Person("古力娜扎", 19)
};
//对数组中的Person对象使用Arrays的sort方法通过年龄进行升序(前边-后边)排序
/*Arrays.sort(arr, new Comparator<Person>() {
@Override
public int compare(Person o1, Person o2) {
return o1.getAge() - o2.getAge();
}
});*/
//使用Lambda表达式,简化匿名内部类
Arrays.sort(arr,(Person o1,Person o2)->{
return o1.getAge() - o2.getAge();
});
//遍历数组
for (Person p : arr) {
System.out.println(p);
}
}
}
Person类
package LambdaTestHaveParameterHaveReturn;
public class Person {
private String name;
private int age;
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public Person() {
}
}
- Lambda表达式的练习(有参数有返回)
类
package LambdaTestHaveParameterHaveReturn2;
/*
需求:
给定一个计算器Calculator接口,内含抽象方法calc可以将俩个int数字相加得到和
使用Lambda表达式调用invokeCalc方法,完成120和130的相加计算
*/
public class Demo01Calculator {
public static void main(String[] args) {
//调用invokeCalc方法,方法的参数是一个接口,使用匿名内部类
invokeCalc(10, 20, new Calculator() {
@Override
public int calc(int a, int b) {
return a+b;
}
});
//使用Lambda表达式简化匿名内部类的书写
invokeCalc(10,20,(int a,int b)->{
return a+b;
});
}
/*定义一个方法,
参数传递俩个int类型的整数
参数传递Calculator接口
方法内部调用Calculator中的方法calc计算俩个整数的和
*/
public static void invokeCalc(int a,int b,Calculator c ){
int sum = c.calc(a,b);
System.out.println(sum);
}
}
接口
package LambdaTestHaveParameterHaveReturn2;
/*
给定一个计算器Calculator接口,内含抽象方法calc可以将俩个int数字相加得到和
*/
public interface Calculator {
//定义一个计算俩个int整数和的方法并返回结果
public abstract int calc(int a, int b);
}
- Lambda表达式的省略写法
Lambda表达式:是可推导,可以省略
凡是根据上下文推导出来的内容,都可以省略书写
可以省略的内容:
1.(参数列表):括号中参数的数据类型,可以省略不写
2.(参数列表):括号中的参数如果只有一个,那么类型和()都可以省略
3.(一些代码):如果{}中的代码只有一行,无论是否有返回值,都可以省略({},return,分号)
注意:要省略{},return,分号,必须一起省略
package LambdaOmit;
import java.util.ArrayList;
/*
Lambda表达式:是可推导,可以省略
凡是根据上下文推导出来的内容,都可以省略书写
可以省略的内容:
1.(参数列表):括号中参数的数据类型,可以省略不写
2.(参数列表):括号中的参数如果只有一个,那么类型和()都可以省略
3.(一些代码):如果{}中的代码只有一行,无论是否有返回值,都可以省略({},return,分号)
注意:要省略{},return,分号,必须一起省略
*/
public class Demo01ArrayList {
public static void main(String[] args) {
//JDK1.7版本之前,创建集合对象必须把前后泛型都写上
ArrayList<String> list01 = new ArrayList<String>();
//JDK1.7之后,=号后边的泛型可以省略,后边的泛型可以根据前边的泛型推导出来
ArrayList<String> list02 = new ArrayList<>();
}
}
优化省略Lambda表达式
//使用Lambda表达式,实现多线程
new Thread(() ->{
System.out.println(Thread.currentThread().getName() + "新线程创建了");
}
).start();
//优化省略Lambda
new Thread(() -> System.out.println(Thread.currentThread().getName() + "新线程创建了")).start();
//使用Lambda表达式简化匿名内部类的书写
invokeCook(()->{
System.out.println("吃饭了!");
});
//优化省略
invokeCook(()-> System.out.println("吃饭了!"));
//使用Lambda表达式,简化匿名内部类
Arrays.sort(arr,(Person o1,Person o2)->{
return o1.getAge() - o2.getAge();
});
//优化省略
Arrays.sort(arr,( o1, o2)-> o1.getAge() - o2.getAge());
//使用Lambda表达式简化匿名内部类的书写
invokeCalc(10, 20, (int a, int b) -> {
return a + b;
});
//优化省略
invokeCalc(10, 20, (a, b) -> a + b);
- Lambda的使用前提