如果抛开实现原理不说,Java中的Lambda表达式可以被当作是匿名内部类的替代品。如果方法的参数是一个函数式接口类型,那么就可以使用Lambda表达式进行替代。使用Lambda表达式作为方法参数,其实就是使用函数式接口作为方法参数。
函数接口作为方法的参数案例:
例如 java.lang.Runnable 接口就是一个函数式接口,
假设有一个 startThread 方法使用该接口作为参数,那么就可以使用Lambda进行传参。
这种情况其实和 Thread 类的构造方法参数为 Runnable 没有本质区别。
代码:
public class Demo01Runnable { //定义一个方法startThread,方法的参数使用函数式接口Runnable public static void startThread(Runnable run){ //开启多线程 new Thread(run).start(); } public static void main(String[] args) { //调用startThread方法,方法的参数是一个接口,那么我们就可以传递这个接口的匿名内部类 startThread(new Runnable() { @Override public void run() { System.out.println(Thread.currentThread().getName()+"-->"+"线程启动了"); } }); //调用startThread方法,方法的参数是一个函数式接口,那么我们就可以传递Lambda表达式 startThread(()->{ System.out.println(Thread.currentThread().getName()+"-->"+"线程启动了"); }); //优化Lambda startThread(()->System.out.println(Thread.currentThread().getName()+"-->"+"线程启动了")); }}1234567891011121314151617181920212223242526
程序演示:
函数接口作为方法的返回值案例:
如果一个方法的返回值类型是一个函数式接口,那么就可以直接返回一个Lambda表达式。
当需要通过一个方法来获取一个java.util.Comparator 接口类型的对象作为排序器时,就可以调该方法获取。
代码:
public class Demo02Comparator { //定义一个方法,方法的返回值类型使用函数式接口Comparator public static Comparator<String> getComparator(){ //方法的返回值类型是一个接口,那么我们可以返回这个接口的匿名内部类 /* return new Comparator<String>() { @Override public int compare(String o1, String o2) { //按照字符产的降序排列 return o2.length()-o1.length(); } };*/ //使用Lambda优化 /* return (String o1, String o2)->{ //按照字符产的降序排列 return o2.length()-o1.length(); };*/ //继续优化 return ( o1, o2)->o2.length()-o1.length(); } public static void main(String[] args) { //创建一个字符串数组 String[] arr = {"aaaa", "b", "ccccccccc", "ddddddddddddd"}; //输出排序前的数组 System.out.println(Arrays.toString(arr)); //调用Arrays中的方法sort,对字符串数组进行排序 Arrays.sort(arr,getComparator()); //输出排序后的数组 System.out.println(Arrays.toString(arr)); }}12345678910111213141516171819202122232425262728293031323334
程序演示:
苏公网安备 32132202001088号
| Copyright 北极熊 北格技术 版权所有