在JDK8之前,将行为抽象化作为参数传递给某个对象方法并进行回调,需要定义一个实现相关接口的类型,如果该类型只需要使用一次,则可通过匿名内部类实现。
在借鉴了C#和Scala后,JDK8引入Lambda表达式,通过减少不必要的模版代码,简化了传递抽象化行为代码的方式。
比如:
Runnable objInnerClass = new Runnable(){
public void run(){
System.out.println("Hello objInnerClass");
}
};
Runnable objLambda = () -> System.out.println("Hello objLambda");
new Thread(objInnerClass).start();
new Thread(objLambda).start();
//还可以使用如下形式
new Thread(new Runnable(){
public void run(){System.out.println("Hello objInnerClass");}
}).start();
new Thread(() -> System.out.println("Hello objLambda")).start();
上述代码分别实例化了两个Runnable对象,其中objInnerClass引用匿名内部类方式实例化的Runnable对象,objLambda引用Lambda表达式实例化的Runnable对象,并分别传递给Thread构造函数,实例化Thread对象,再调用start方法启动线程执行。通过多线程编码场景,我们可以一目了然的看出,JDK8引入的Lambda表达式语法减少了匿名内部类中的模板代码,简化了开发者的代码编写,且代码的可读性更好。而Lambda表达式的使用,正是函数式编程的体现。我们应该循着JDK的不断演变,将JDK8的Lambda表达式引入我们的代码,将函数式编程引入我们的思维,从而更好的改善我们的代码质量。