jdk1.8新特性讲解(二)

简介: jdk1.8新特性讲解(二)

1、方法与构造函数引用


前一节中的代码还可以通过静态方法引用来表示:


代码如下:


Converter<String, Integer> converter = Integer::valueOf; 
Integer converted = converter.convert("123");
System.out.println(converted); // 123
复制代码


Java 8 允许你使用 :: 关键字来传递方法或者构造函数引用,上面的代码展示了如何引用一个静态方法,我们也可以引用一个对象的方法:


代码如下:


converter = something::startsWith;
String converted = converter.convert("Java"); 
System.out.println(converted); // "J"
复制代码


接下来看看构造函数是如何使用::关键字来引用的,首先我们定义一个包含多个构造函数的简单类:

代码如下:


class Person {
    String firstName;
    String lastName;
    Person() {
    }
    Person(String firstName, String lastName) {
        this.firstName = firstName; 
        this.lastName = lastName; 
    }
}
复制代码



接下来我们指定一个用来创建Person对象的对象工厂接口:

代码如下:


interface PersonFactory<P extends Person> {
    P create(String firstName, String lastName); 
}
复制代码

这里我们使用构造函数引用来将他们关联起来,而不是实现一个完整的工厂:

代码如下:

PersonFactory personFactory = Person::new; Person person =

personFactory.create("Peter", "Parker");

我们只需要使用 Person::new 来获取Person类构造函数的引用,Java编译器会自动根据PersonFactory.create方法的签名来选择合适的构造函数。




2、Lambda 作用域


在lambda表达式中访问外层作用域和老版本的匿名对象中的方式很相似。你可以直接访问标记了final的外层局部变量,或者实例的字段以及静态变量。



3、访问局部变量


我们可以直接在lambda表达式中访问外层的局部变量:

代码如下:


final int num = 1; 
Converter<Integer, String> stringConverter = (from) -> String.valueOf(from + num);
stringConverter.convert(2); // 3
复制代码

但是和匿名对象不同的是,这里的变量num可以不用声明为final,该代码同样正确:

代码如下:


int num = 1; Converter<Integer, String> stringConverter = (from) -> String.valueOf(from + num);

stringConverter.convert(2); // 3


不过这里的num必须不可被后面的代码修改(即隐性的具有final的语义),例如下面的就无法编译:


代码如下:


int num = 1; 
Converter<Integer, String> stringConverter = (from) -> String.valueOf(from + num);
num = 3;
复制代码

在lambda表达式中试图修改num同样是不允许的。




四、访问对象字段与静态变量


和本地变量不同的是,lambda内部对于实例的字段以及静态变量是即可读又可写。该行为和匿名对象是一致的:


代码如下:

class Lambda4 { 
    static int outerStaticNum; 
    int outerNum;
    void testScopes() { 
        Converter<Integer, String> stringConverter1 = (from) -> { 
            outerNum = 23;
            return String.valueOf(from); 
        };
       Converter<Integer, String> stringConverter2 = (from) -> {  
           outerStaticNum = 72; 
           return String.valueOf(from); 
      }; 
   } 
}




相关文章
|
13天前
|
容器
jdk8新特性-详情查看文档
jdk8新特性-详情查看文档
34 7
|
3月前
|
容器
jdk8新特性-详情查看文档
jdk8新特性-详情查看文档
47 3
|
2月前
|
存储 安全 Java
JDK1.8 新的特性
JDK1.8 新的特性
26 0
|
3月前
|
编解码 安全 Java
jdk8新特性-接口和日期处理
jdk8新特性-接口和日期处理
|
4月前
|
Java API
JDK8到JDK25版本升级的新特性问题之使用Collectors.teeing()来计算一个列表中学生的平均分和总分如何操作
JDK8到JDK25版本升级的新特性问题之使用Collectors.teeing()来计算一个列表中学生的平均分和总分如何操作
|
4月前
|
Java API Apache
JDK8到JDK24版本升级的新特性问题之在Java中,HttpURLConnection有什么局限性,如何解决
JDK8到JDK24版本升级的新特性问题之在Java中,HttpURLConnection有什么局限性,如何解决
|
4月前
|
Oracle Java 关系型数据库
JDK8到JDK29版本升级的新特性问题之未来JDK的升级是否会成为必然趋势,如何理解
JDK8到JDK29版本升级的新特性问题之未来JDK的升级是否会成为必然趋势,如何理解
|
4月前
|
Oracle 安全 Java
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
|
4月前
|
Java API 开发者
JDK8到JDK17版本升级的新特性问题之SpringBoot选择JDK17作为最小支持的Java lts版本意味着什么
JDK8到JDK17版本升级的新特性问题之SpringBoot选择JDK17作为最小支持的Java lts版本意味着什么
146 0
JDK8到JDK17版本升级的新特性问题之SpringBoot选择JDK17作为最小支持的Java lts版本意味着什么
|
3月前
|
Java 编译器 API
JDK8新特性--lambda表达式
JDK8的Lambda表达式是Java语言的一大进步。它为Java程序提供了更多的编程方式,让代码更加简洁,也让函数式编程的概念在Java中得到了体现。Lambda表达式与Java 8的其他新特性,如Stream API、新的日期时间API一起,极大地提高了Java编程的效率和乐趣。随着时间的流逝,Java开发者对这些特性的理解和应用将会越来越深入,进一步推动Java语言和应用程序的发展。
16 0