JavaSE---方法引用

1、双冒号 ::为方法引用运算符,它所在的表达式称为方法引用。

如果lambda表达式要表达的函数方案已经存在于某个方法的实现中,则可以通过双冒号来引用该方法作为lambda表达式的替代者。

注意:lambda表达式中传递的参数一定是方法引用中可以接收的类型,否则会抛出异常。

举例:

str -> System.out.println(str): 这个一个输出字符串的lambda表达式,它是指在拿到参数之后,经lambda之手传递给                                                                       System.out.println方法进行处理。

System.out::println : 方法引用的写法,是指直接让System.out对象的println方法来取代lambda表达式,直接执行该方法。

  这两种写法的效果完全一样,而第二种写法复用了已有的方案,更加简洁。

2、通过对象名可引用成员方法

举例

定义函数式接口 PrintMsg

@FunctionalInterface
public interface PrintMsg {
    void msgPrint(String str);
}

定义一个类 MyString

public class MyString {

    public void mehtod(String str){
        System.out.println(str.toUpperCase());
    }
}

定义一个方法print,参数传递接口,如以下所示,三种调用方式的效果是一样的。

public class Test {

    public static void print(String str, PrintMsg pm){
        pm.msgPrint(str);
    }

    public static void main(String[] args) {

        print("hello world!!!",(str)->{
            MyString obj = new MyString();
            obj.mehtod(str);
        });

        print("hello world!!!",str -> new MyString().mehtod(str));

        MyString obj = new MyString();
        print("hello world!!!",obj::mehtod);
    }
}

3、通过类名称引用静态成员方法

举例

定义一个接口 CalAbs

@FunctionalInterface
public interface CalAbs {
    int numAbs(int num);
}

public class TestCalAbs {

    public static void method(int num,CalAbs ca){
        System.out.println(ca.numAbs(num));
    }

    public static void main(String[] args) {

        method(-10,(num)->{
            return Math.abs(num);
        });

        method(-20,Math::abs);
    }
}

4、使用Super引用父类的成员方法

举例

定义接口 Common

@FunctionalInterface
public interface Common {
    void funCommon();
}

定义父类

public class Fu {

    public void method(){
        System.out.println("我是Fu类!!!");
    }
}

定义子类,四种方法是等效的

public class Zi extends Fu {

    @Override
    public void method() {
        super.method();
        System.out.println("我是Zi类!!!");
    }

    public void funCom(Common com){
        com.funCommon();
    }

    public void show(){
        // 1
        funCom(()->{
            Fu f = new Fu();
            f.method();
        });

        // 2
        Fu f = new Fu();
        funCom(f::method);
        
        // 3
        funCom(()->super.method());
        
        // 4
        funCom(super::method);
    }

    public static void main(String[] args) {
        Zi obj = new Zi();
        obj.show();
    }
}

5、通过this调用本类的成员方法

举例

定义接口Alive

@FunctionalInterface
public interface Alive {
    void eat();
}

定义Person类

public class Person {
    private String food;

    public Person(String food) {
        this.food = food;
    }

    public void show(){
        System.out.println("我喜欢吃"+food);
    }

    public void method(Alive alive){
        alive.eat();
    }

    public void method01(){

        method(()->{
            this.show();
        });

        method(()->this.show());

        method(this::show);
    }

    public static void main(String[] args) {
        new Person("apple").method01();
    }
}

6、类的构造器引用

举例

定义接口Personbuilder

@FunctionalInterface
public interface Personbulider {
    Person BuliderPerson(String name);
}

定义Person类

public class Person {
    private String name;

    public Person() {
    }

    public Person(String name) {
        this.name = name;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

定义测试函数,三种调用Person类构造器的效果是一样的。

public class TestPerson {

    public static void printPerson(String name,Personbulider pb){
        Person person = pb.BuliderPerson(name);
        System.out.println(person.getName());
    }

    public static void main(String[] args) {

        printPerson("Rose",(str)->{
            return new Person(str);
        });

        printPerson("Jack",str->new Person(str));

        printPerson("Lily",Person::new);
    }
}

7、数组的构造器引用

举例

定义ArrayBuilder接口

@FunctionalInterface
public interface ArrayBuilder {
    int[] builderIntArray(int length);
}

创建数组,数组的类型和长度已知,引用new来根据参数传递的长度来创建数组。

public class TestArrayBuilder {

    public static int[] createIntArray(int length,ArrayBuilder ab){
        return ab.builderIntArray(length);
    }

    public static void main(String[] args) {
        int[] array = createIntArray(10,(len)->{
            return new int[len];
        });
        
        int[] array01 = createIntArray(20,(len)->new int[len]);

        int[] array02 = createIntArray(30,int[]::new);

    }

}

 

### 回答1: 这个问题是因为导入的项目引用了一个未知的JDK版本javase-1.8。可能是因为你的电脑上没有安装这个版本的JDK,或者项目中使用了一个非标准的JDK版本。你需要安装或配置正确的JDK版本来解决这个问题。 ### 回答2: 当我们导入一个已存在的项目时,有时候我们会遇到一个错误提示:imported project refers to unknown jdks javase-1.8。这个错误的意思是导入的项目引用了未知的JDK版本,通常是因为我们的开发环境没有安装或者没有正确配置JDK版本导致的。 解决这个问题的方法是安装或者重新配置JDK版本。首先我们需要确保我们本机已经安装了JDK1.8版本,如果没有,请先前往Oracle官网下载并安装。在安装JDK时需要注意是把JDK的安装路径添加到系统环境变量中,这样IDE才能找到JDK的路径。 如果已经安装了JDK1.8版本,则需要在IDE中正确配置项目的JDK版本。进入IDE的设置菜单,在“Project Settings”中选择“Project”,在“Project SDK”中选择JDK1.8版本即可。 如果还是出现了错误提示,可以尝试在IDE中重新设置JDK的路径。在IDE的设置菜单中选择“Project Structure”,在“SDKs”中可以看到已安装的JDK列表,选择JDK1.8并修改其安装路径即可。 总的来说,当出现“imported project refers to unknown jdks javase-1.8”这个错误时,我们需要重点检查JDK的安装和配置是否正确。只有正确安装和配置了JDK,才能解决这个问题。 ### 回答3: 这个问题是由于导入的项目没有正确的连接到Java Development Kit(JDK)的版本而导致的。首先需要检查项目的构建路径及环境变量是否已经正确设置。在Eclipse中,打开项目的属性对话框,点击“Java Build Path”,在“Libraries”选项卡中,可以看到所有已经加入的库和JDK,确保JDK的版本与项目所需要运行的版本一致即可。 如果JDK已经正确设置,但是引用的库仍然无法识别Java 1.8则需要检查项目是否正确设置编译等级。在Eclipse中,同样在项目的属性对话框中,点击“Java Compiler”选项卡,确保编译等级为Java 1.8或以上版本。 如果上述步骤都没有解决问题,则需要检查系统的环境变量是否正确设置。在Windows系统中,可以通过“开始菜单 -> 此电脑 -> 属性 -> 高级系统设置 -> 环境变量”来查看和修改环境变量。在系统变量中,查找“JAVA_HOME”变量,确保指向Java 1.8或以上版本的安装路径。 最后,如果所有的设置都没有解决问题,则可能需要重新安装JDK或者使用其他版本的JDK来进行编译和运行。需要注意的是,一些库可能只支持特定版本的JDK,需要根据具体情况来选择正确的JDK版本。 在解决此问题之前,一定要多备份项目的代码,避免操作误操作导致代码丢失。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值