【发布时间】:2014-08-08 01:10:47
【问题描述】:
在 java 8 中我有这样的东西:
package test;
public class SimpleFuncInterfaceTest {
public static void carryOutWork(AFunctionalInterface sfi){
sfi.doWork();
}
public static void main(String[] args) {
carryOutWork(() -> System.out.println("Do work in lambda exp impl..."));
AImplementor implementsA = new AImplementor();
//carryOutWork(() -> implementsA.doWork());
BImplementor implementsB = new BImplementor();
carryOutWork(() -> implementsB.doWork());
}
}
@FunctionalInterface
interface AFunctionalInterface {
public void doWork();
default public void doSomeWork(){
System.out.println("FOO");
}
}
@FunctionalInterface
interface BFunctionalInterface extends AFunctionalInterface {
@Override
default public void doSomeWork(){
System.out.println("BAR");//Unreachable in same object?
}
}
class AImplementor implements AFunctionalInterface {
@Override
public void doWork() {
doSomeWork();
}
}
class BImplementor extends AImplementor implements BFunctionalInterface {
public void doSomeWork(){
super.doSomeWork();
new BFunctionalInterface(){
@Override
public void doWork() {
}}.doSomeWork();
System.out.println("WUK WUK");
}
@Override
public void doWork() {
doSomeWork();
}
}
有没有一种方法可以从 implementsB 调用默认的函数式接口行为,而不必创建匿名内部类并调用它?
这有一个副作用(调用 implementsA 的方法 2 次),需要调用父级的实现,然后让子级的实现能够调用子级的默认实现,以及一些特殊化(如果需要)。如您所见,调用父级的实现非常容易,但是我看不到避免重写默认实现的方法,除非我向实现子接口的类添加一层间接层,并且无法强制执行.
例如,如果 A 解锁或提供对资源的访问权限(例如数据库),而 B 解锁第二个资源(另一个数据库),我认为没有办法让代码解锁 A,然后 B 通过使用功能接口执行此合同,要求调用 A 和 B。 一层深你可以做到,但 N 层深看起来是不可能的。
我打算使用 lambdas 来避免进行昂贵的调用,而是对我的库用户强制执行操作的语义顺序。
这个问题不与“显式调用 Java 中的默认方法”完全一样,因为这个问题是关于 N 级深度的接口,而不仅仅是调用父接口的默认方法。
【问题讨论】:
-
所以你想从
BImplementor打电话给BFunctionalInterface.doSomeWork? -
与“在 Java 中显式调用默认方法”不同的问题,它询问 N 级深度,而该解决方案仅允许单级间接。
标签: java java-8 default-method functional-interface