JDK8新特性之Lambda表达式
2015-05-01 17:23
555 查看
Lambda表达式主要是替换了原有匿名内部类的写法,也就是简化了匿名内部类的写法。lambda语法结构:
先看一个使用匿名内部类定义一个新线程的方法:
使用lambda表达式则可以简化匿名内部类的写法:
好吧,代码是不是极大的简化了?
再来看看一个例子,传统方法过滤一个文件夹中的文件是这样的:
使用了lambda表达式之后怎样过滤文件呢?
lambda表达式,既然是一种表达式,它就不是内部类,这样编译过后不会产生内部类,它只是内部类的另一种实现方式。
再看看给Set集合排序的例子:
传统方式是这样的:
使用了lambda表达式之后呢?
lambda局限性:
1.如果接口有多个方法需要实现,就只能通过匿名内部类来实现,而不可以使用lambda表达式。
2.要使用lambda表达式的地方参数本身就是固定的,只有一个,例如new Thread(),要么没有参数,要么只能是new Runnable().
(参数1,参数2...)->{重写方法的内容,不定义方法名}
先看一个使用匿名内部类定义一个新线程的方法:
@Test public void test1(){ new Thread(new Runnable() { @Override public void run() { for(int x=0;x<100;x++){ System.out.println("run..."+x); } } }).start(); for(int x=0;x<100;x++){ System.out.println("main..."+x); } }
使用lambda表达式则可以简化匿名内部类的写法:
@Test public void test2(){ new Thread(()->{ for(int i=0;i<100;i++){ System.out.println("run..."+i); } }).start(); for(int i=0;i<100;i++){ System.out.println("main..."+i); } }
好吧,代码是不是极大的简化了?
再来看看一个例子,传统方法过滤一个文件夹中的文件是这样的:
@Test public void test3(){ File file = new File("F:\\test"); File[] fs = file.listFiles(new FileFilter() { @Override public boolean accept(File pathname) { //获取所有的xml文件 return pathname.getName().endsWith(".xml"); } }); for(File f:fs){ System.out.println(f.getName()); } }
使用了lambda表达式之后怎样过滤文件呢?
@Test public void test4(){ File file = new File("F:\\test"); //注意这里pathname前面的String不写 File[] fs = file.listFiles((pathname)->{ return pathname.getName().endsWith(".xml"); }); for(File f:fs){ System.out.println(f.getName()); } }
lambda表达式,既然是一种表达式,它就不是内部类,这样编译过后不会产生内部类,它只是内部类的另一种实现方式。
再看看给Set集合排序的例子:
传统方式是这样的:
@Test public void test5() { Set<String> set = new TreeSet<String>(new Comparator<String>() { @Override public int compare(String o1, String o2) { return o1.length() - o2.length() == 0 ? o1.compareTo(o2) : o1.length() - o2.length(); } }); set.add("ac"); set.add("acfa"); set.add("acfadfada"); set.add("ac5423543534524"); System.out.println(set); }
使用了lambda表达式之后呢?
@Test public void test6() { //注意这里的参数名可以自定义 Set<String> set = new TreeSet<String>((s1,o2)->{ return s1.length() - o2.length() == 0 ? s1.compareTo(o2) : s1.length() - o2.length(); }); set.add("ac"); set.add("acfa"); set.add("acfadfada"); set.add("ac5423543534524"); System.out.println(set); }
lambda局限性:
1.如果接口有多个方法需要实现,就只能通过匿名内部类来实现,而不可以使用lambda表达式。
2.要使用lambda表达式的地方参数本身就是固定的,只有一个,例如new Thread(),要么没有参数,要么只能是new Runnable().
相关文章推荐
- jdk8新特性->lambda表达式
- JDK8新特性之Lambda表达式
- jdk8新特性 lambda表达式详解
- JDK8新特性之Lambda表达式
- JDK8新特性之Lambda表达式
- JDK8新特性之Lambda表达式
- 扫盲贴(一)——JDK8新特性:Lambda表达式入门
- JDK8新特性之Lambda表达式
- jdk8新特性:Lambda表达式(也称为闭包、可传递的匿名函数)与函数式接口@FunctionalInterface
- jdk8新特性之lambda表达式
- 深入浅析JDK8新特性之Lambda表达式
- javaSE_8系列博客——Java语言的特性(三)--类和对象(20)--嵌套类(Lambda 表达式--VS--方法引用)
- 为LINQ服务的C#新特性总结篇---扩展方法,匿名委托,lambda表达式,Action委托,Func委托,Linq中的order by,top和sum函数
- C#特性 学习笔记(Lambda表达式 迭代)
- java8新特性 lambda表达式
- JDK8新特性之Lambda表达式
- W3Cschool Java 8新特性----> Lambda 表达式
- C++11 新特性:Lambda 表达式
- C++11新特性:lambda表达式
- C#3.0语言新特性之Lambda表达式