1. java8 lambda 表达式是个什么
为了支持函数式编程,Java 8引入了Lambda表达式.
在Java 8中采用的是内部类来实现Lambda表达式.具体实现代码,可以通过debug看, 同时通过字节码查看工具及反编译工具来验证.
自从lambda表达式成为Java语言的一部分之后,Java集合(Collections)API就面临着大幅变化。而JSR 355(规定了Java lambda表达式的标准)的正式启用更是使得Java集合API变的过时不堪。
尽管我们可以从头实现一个新的集合框架(比如“Collection II”),但取代现有的集合框架是一项非常艰难的工作,因为集合接口渗透了Java生态系统的每个角落,将它们一一换成新类库需要相当长的时间。因此,我们决定采取演化的策略(而非推倒重来)以改进集合API: 为现有的接口(例如Collection,List和Stream)增加扩展方法;
在类库中增加新的流(stream,即java.util.stream.Stream)抽象以便进行聚集(aggregation)操作;
改造现有的类型使之可以提供流视图(stream view);
改造现有的类型使之可以容易的使用新的编程模式,这样用户就不必抛弃使用以久的类库,例如ArrayList和HashMap
(当然这并不是说集合API会常驻永存,毕竟集合API在设计之初并没有考虑到lambda表达式。我们可能会在未来的JDK中添加一个更现代的集合类库)。
除了上面的改进,还有一项重要工作就是提供更加易用的并行(Parallelism)库。尽管Java平台已经对并行和并发提供了强有力的支持,然而开发者在实际工作(将串行代码并行化)中仍然会碰到很多问题。因此,我们希望Java类库能够既便于编写串行代码也便于编写并行代码,因此我们把编程的重点从具体执行细节(how computation should be formed)转移到抽象执行步骤(what computation should be perfomed)。
2. JAVA8的lambda表达式的一个问题
这个功能性/函数接口主要用做转换的作用。Converter<String, Integer> converter = (from) -> Integer.valueOf(from);这就是lambda表达式, (from) -> Integer.valueOf(from)这个是具体的实现, 这句话的意思将输入的字符串from,经过转换后输出整数。当然你可以自己实现一个转换逻辑,比如 Converter<String, Integer> converter =
str -> customConvert(str)。
下面就是自己实现的一个转化器。
private Integer customConvert(String str){
return 1;//这样输入的字符串永远都输出1;
}
3. java表达式是什么
Java是面向表达式的语言,Java中一个简单表达式可以是下面任意一种:● 常量:7、false。● 单引号括起来的字符字面常量:'A'、'3'。● 双引号括起来的字符串字面常量:"foo"、"Java"。● 任何正确声明的变量名:myString、x。● 任何用Java二元运算符(本章稍后将详细讨论)连接起来的两个上述类型的表达式:x+2。● 任何用Java一元运算符(本章稍后将详细讨论)修饰的单个上述类型的表达式:i++。● 任何用小括号括起来的上述类型的表达式:(x+2)。以及另外一些与本书后面将要学到的对象有关的表达式类型。无论多么复杂的表达式都可以由不同类型的简单表达式和括号嵌套组合而成,例如:((((4/x) + y) * 7) + z)。2.9.1 算术运算符 Java语言提供了许多基本的算术运算符,如表2-1所示。表2-1 Java算术运算符运算符描 述+加法-减法*乘法/除法%求余(%左边的操作数除以右边的
操作数所得到的余数,例如10%3=1)+和-运算符也可作为一元运算符用于表示正负数:-3.7、+42。除了简单赋值运算符=,还有许多特定的复合赋值运算符,这些运算符将变量赋值和算术操作合并在一起,如表2-2所示。表2-2 Java复合赋值运算符运算符描 述+=a+=b等价于a=a+b-=a-=b等价于a=a-b*=a*=b等价于a=a*b/=a/=b等价于a=a/b%=a%=b等价于a=a%b最后要介绍的两个算术运算符是一元递增运算符(++)和一元递减运算符(--),用于将整数变量的值加1或减1,或者将浮点数变量的值加1.0或减1.0。称它们为一元运算符是因为它们用于单个变量,而前面讨论的二元运算符则连接两个表达式的值。一元递增运算符和一元递减运算符也可用于将字符变量在Unicode序列中向前或向后移动一个字符位置。例如,在下面的代码片段中,字符变量c的值从'e'递增为'f':递增和递减运算符可以以前缀或者后缀方式使用。如果运算符放在操作数之前(前缀模式),变量的递增或递减操作将在更新后的变量值被用于任何由它构成的赋值操作之前执行。例如,考虑下面的使用前缀递增运算符的代码片段,假设a和b在程序前面已经声明为int变量:上述代码执行后,变量a的值是2,变量b的值也是2。这是因为在第二行中变量a的递增(从1到2)发生在它的值赋给b之前。因此这行代码在逻辑上等价于下面两行代码: 另一方面,如果运算符放在操作数之后(后缀模式),递增或递减操作发生在原来的变量值被用于任何由它构成的赋值操作之后。看一下以后缀方式使用递增运算符的相同代码片段:上述代码执行后,变量b的值是1,而变量a的值是2。这是因为在第二行中变量a的递增(从1到2)发生在它的值赋给b之后。因此这行代码在逻辑上等价于下面两行代码:下面是一个稍微复杂一点例子,请阅读附加的注释以确保你能够明白x最终是如何被赋值为10的:稍后将会看到,递增和递减运算符通常和循环一起使用。2.9.2 关系和逻辑运算符逻辑表达式以指定的方式比较两个(简单或者复杂)表达式exp1和exp2,决议出一个boolean值true或者false。 Java提供了表2-3所示的关系运算符来创建逻辑表达式。表2-3 Java关系运算符运算符描 述exp1==exp2如果exp1等于exp2,值为true(注意使用双等号测试相等性)exp1>exp2如果exp1大于exp2,值为trueexp1>=exp2如果exp1大于等于exp2,值为trueexp1<exp2如果exp1小于exp2,值为trueexp1<=exp2如果exp1小于等于exp2,值为trueexp1!=exp2如果exp1不等于exp2,值为true!exp如果exp为false值为true,如果exp为true值为false除了关系运算符,Java还提供了用于组合/修饰逻辑表达式的逻辑运算符。表2-4列出了最常用的逻辑运算符。表2-4 Java逻辑运算符运算符描 述exp1&&exp2逻辑“与”,仅当exp1和exp2都为true时复合表达式值为trueexp1||exp2逻辑“或”,exp1或exp2值为true时复合表达式值为true!exp逻辑“非”,将逻辑表达式的值从true切换到false,反之亦然下面这个例子用逻辑“与”运算符来编程实现逻辑表达式“如果x大于2.0且y不等于4.0”:逻辑表达式常用于流程控制结构,本章稍后将进行讨论。2.9.3 表达式求值和运算符优先级如同本章前面提到的那样,任何复杂的表达式都可以用分层嵌套的小括号构成,例如(((8 * (y + z)) + y) x)。编译器通常按照从内到外,从左到右的顺序对这样的表达式求值。假设x、y、z按照下面的方式声明并初始化:下面的赋值语句右边的表达式:将像下面这样逐步求值:没有小括号时,根据运算符用于表达式求值的顺序,某些运算符具有高于其他运算符的优先级。例如,乘除法先于加减法执行。通过使用小括号可以强制改变运算符的优先级,括号内的运算符比括号外的先执行。考虑下面的代码片段:代码的第一行没有使用括号,乘法操作比加法操作先执行,因此整个表达式的值为2+12=14,就像我们将表达式明确地写成2+(3*4)一样,当然这样做没有必要。 在代码的第二行,括号被明确地放在操作2+3两边,因此加法操作将首先执行,然后求和结果乘以4作为整个表达式的值,即5*4=20。回到前面的例子注意到>和!=运算符优先级高于&&运算符,因此可以去掉嵌套的括号而变成下面这样:然而,额外的括号并不会对代码造成伤害,事实上它可以使表达式的目的更加清楚。2.9.4 表达式类型表达式类型是表达式最终求值结果的Java类型。例如给定下面的代码片段:表达式(x > 2.0) && (y != 4.0)求值结果为true,因此表达式(x > 2.0) && (y != 4.0)称为boolean型表达式。在下面的代码片段中:表达式((8 * (y + z)) + y) * x求值结果为42,因此表达式((8 * (y + z)) + y) * x称为整型表达式。
4. Java 8的新特性lambda表达式是否比匿名内部类具有更好的可读性
对于大多数刚刚接触jdk8的同学来说,应该都会认为lambda表达式其实就是匿名内部类的语法糖(包括我自己,在刚刚接触的时候,也是这样认为的),但实际上二者还是存在不少差异,其中最主要的两点就是标识性和作用域。
首先,内部类在创建表达式时,会确保创建一个拥有唯一标识的新对象,而对于lambda,其计算结果(其实就是一个映射的过程)可能有也可能没有唯一标识,这取决于具体实现。
其次,内部类的声明会创建出一个新的命名作用域,在这个作用域中,this与super指向内部类本身的当前实例;但是lambda恰恰相反,它不会引入任何新的命名环境,这样就避免了内部类名称查找的复杂性,名称查找会导致很多问题,比如想要调用外围实例的方法时却错误的调用了内部类实例的Object方法。
5. java8 中的->和::是什么意思呢
->是Java 8新增的Lambda表达式中,变量和临时代码块的分隔符,即:
(变量) -> {代码块}
如果代码块只有一个表达式,大括号可以省略。如果变量类型可以自动推断出来,可以不写变量类型。
::是类似于C++的域运算符,获取方法使用的。
stream()也是JDK8新增的流,你的表达式中将numbers转换为流,就可以惰性处理,这样只有变量要用的时候才会被调用,专门处理较多的数字或者字符串(如配合readAllLines()方法使用),i -> i % 2 == 0就是自动判断了i的类型(可能是int型,我没法判断),这样就将numbers中所有的偶数过滤出来了(distinct()保证了每个数字只保留一个),然后将这些过滤出的数字每个占用一行地打印出来。
6. Java 8为什么需要Lambda表达式
很多编程语言早就引入了Lambda 表达式
而java语法又比较繁琐,被很多人嫌弃.
于是java8新增了特性支持Lambda 表达式.
例如:
不用Lambda表达式写的匿名内部类
List<String> names = Arrays.asList("jack", "tom", "jerry");
Collections.sort(names, new Comparator<String>() {
@Override
public int compare(String s1, String s2) {
return s2.compareTo(s1);
}
});
采用Lambda表达式简化上面的代码
List<String> names = Arrays.asList("jack", "tom", "jerry");
Collections.sort(names, (s1, s2) -> s2.compareTo(s1));
当然了java8中Lambda表达式还有其他用法,但我比较喜欢它的简洁
7. Java 8的Lambda表达式为什么要基于invokedynamic
很多编程语言早就引入了Lambda表达式而java语法又比较繁琐,被很多人嫌弃.于是java8新增了特性支持Lambda表达式.例如:不用Lambda表达式写的匿名内部类List names = Arrays.asList("jack", "tom", "jerry");Collections.sort(names,
8. 如何在android studio中使用java8 的Lambda表达式
1、下载Java8的jdk进行安装。
2、然后在Andstudio中打开Project Structure 设置一下JDK的路径。
3、在项目中bulid.gradle中 将jdk版本更改为JavaVersion.VERSION_1_8
4、到这时候 已经可以在项目中书写 Lambda语法 而不会报错了,但是 当编译的时候还是会报 class file for java.lang.invoke.MethodType not found #23 这个错,
这时候只要在工程的bulid.gradle中的buildscript里去配置下:classpath 'me.tatarka:gradle-retrolambda:3.2.4' 。
5、最后在app的bulid.gradle中加上 apply plugin: 'me.tatarka.retrolambda' 就OK了。
完成以上步骤,就能在androidstudio中使用Lambda 表达式了。
9. Java8新特性lambda表达式有什么用
一:因为lambda表达式能够使代码看起来更简洁,清爽
匿名内部类的写法
List<String>names=Arrays.asList("jack","tom","jerry");
Collections.sort(names,newComparator<String>(){
@Override
publicintcompare(Strings1,Strings2){
returns2.compareTo(s1);
}
});
lambda表达式的写法
List<String>names=Arrays.asList("jack","tom","jerry");
Collections.sort(names,(s1,s2)->s2.compareTo(s1));
二: 很多编程语言都支持lambda表达式. java不支持都不好意思了......
三: 通过lambda 表达式 来实现函数是编程.将来声明式编程语言借鉴函数编程思想,函数编程语言融合声明式编程特性...这几乎是一种必然趋势。
10. java8新特性lambda表达式有什么用
一:因为lambda表达式能够使代码看起来更简洁,清爽
匿名内部类的写法
List<String>names=Arrays.asList("jack","tom","jerry");
Collections.sort(names,newComparator<String>(){
@Override
publicintcompare(Strings1,Strings2){
returns2.compareTo(s1);
}
});
lambda表达式的写法
List<String>names=Arrays.asList("jack","tom","jerry");Collections.sort(names,(s1,s2)->s2.compareTo(s1));
二: 很多编程语言都支持lambda表达式. java不支持都不好意思了......
三: 通过lambda 表达式 来实现函数是编程.将来声明式编程语言借鉴函数编程思想,函数编程语言融合声明式编程特性...这几乎是一种必然趋势。