java中接口函数_java中函数接口实例的等价

您可以将方法引用存储到变量中:

public static void main(String[] args) {

HashSet set = new HashSet<>();

FunctionSet functionSet = new FunctionSet();

Element fn = functionSet::doubleUp;

set.add(fn);

set.add(functionSet::square);

System.out.println(set.add(fn));

}

这样它返回false.

在不同的代码位置创建相同的labmda或方法引用时,它与在两个位置创建新的匿名类大致相同:

public static void main(String[] args) {

HashSet set = new HashSet<>();

FunctionSet functionSet = new FunctionSet();

set.add(new Element() {

@Override

public void doSomething(int a) {

functionSet.doubleUp(a);

}

});

set.add(new Element() {

@Override

public void doSomething(int a) {

functionSet.square(a);

}

});

System.out.println(set.add(new Element() {

@Override

public void doSomething(int a) {

functionSet.doubleUp(a);

}

}));

}

所以每次它都是一个不同的对象,虽然看起来可能是一样的.对于每个遇到的方法引用,在运行时创建单独的匿名类:

Element e1 = functionSet::doubleUp;

Element e2 = functionSet::doubleUp;

System.out.println(e1.getClass());

System.out.println(e2.getClass());

输出将是这样的:

class FunctionSet$$Lambda$1/918221580

class FunctionSet$$Lambda$2/1554547125

所以实际上它是两个不同类的两个不同的对象.如果不比较它们的字节码就很难得出它们做同样的事情.还要注意它们都捕获了functionSet变量,因此还应该确保它在两个方法引用之间没有被更改.

我能想到的唯一解决方法是将所有方法引用声明为代码中的常量,然后引用它们而不是直接使用方法引用:

public static final Element FN_DOUBLE_UP = new FunctionSet()::doubleUp;

public static final Element FN_SQUARE = new FunctionSet()::square;

public static void main(String[] args) {

HashSet set = new HashSet<>();

set.add(FN_DOUBLE_UP);

set.add(FN_SQUARE);

System.out.println(set.add(FN_DOUBLE_UP));

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值