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); 
      }; 
   } 
}




相关文章
|
7月前
|
Java 测试技术 调度
JDK21有没有什么稳定、简单又强势的特性?
这篇文章主要介绍了Java虚拟线程的发展及其在AJDK中的实现和优化。
JDK21有没有什么稳定、简单又强势的特性?
|
10月前
|
容器
jdk8新特性-详情查看文档
jdk8新特性-详情查看文档
150 7
|
容器
jdk8新特性-详情查看文档
jdk8新特性-详情查看文档
127 3
|
存储 安全 Java
JDK1.8 新的特性
JDK1.8 新的特性
140 0
|
Java API
JDK8到JDK25版本升级的新特性问题之使用Collectors.teeing()来计算一个列表中学生的平均分和总分如何操作
JDK8到JDK25版本升级的新特性问题之使用Collectors.teeing()来计算一个列表中学生的平均分和总分如何操作
|
Java API Apache
JDK8到JDK24版本升级的新特性问题之在Java中,HttpURLConnection有什么局限性,如何解决
JDK8到JDK24版本升级的新特性问题之在Java中,HttpURLConnection有什么局限性,如何解决
|
Oracle Java 关系型数据库
JDK8到JDK29版本升级的新特性问题之未来JDK的升级是否会成为必然趋势,如何理解
JDK8到JDK29版本升级的新特性问题之未来JDK的升级是否会成为必然趋势,如何理解
|
Oracle 安全 Java
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
|
Java API 开发者
JDK8到JDK17版本升级的新特性问题之SpringBoot选择JDK17作为最小支持的Java lts版本意味着什么
JDK8到JDK17版本升级的新特性问题之SpringBoot选择JDK17作为最小支持的Java lts版本意味着什么
394 0
JDK8到JDK17版本升级的新特性问题之SpringBoot选择JDK17作为最小支持的Java lts版本意味着什么
|
编解码 安全 Java
jdk8新特性-接口和日期处理
jdk8新特性-接口和日期处理