繁体   English   中英

如何使用方法引用作为将来的回调?

[英]How to use method reference as future callback?

当我尝试使用这样的东西

class Example {
    ...

    private Future<String> asyncMethod() {
        ...
        return somePromise;
    }

    private static void callback(Future<String> future) {
        System.out.println(future.getNow());
    }

    public static void main(String[] args) {
        asyncMethod().addListener(Example::callback);
    }
}

我得到一个错误

Example.java:[17,34] incompatible types: invalid method reference
   incompatible types: io.netty.util.concurrent.Future<capture#1 of ? super java.lang.String>
   cannot be converted to io.netty.util.concurrent.Future<java.lang.String>

匿名类作为侦听器没有任何错误

asyncMethod().addListener(new GenericFutureListener<Future<String>>() {
    @Override
    public void operationComplete(Future<String> future) throws Exception {
        System.out.println(future.getNow());
    }
});

但这很丑陋和冗长:(我该怎么做才能以最优雅的方式解决这个问题?

您可以强制转换方法参考

asyncMethod().addListener((GenericFutureListener<Future<String>>) Example::callback);

它不那么冗长,但仍然不够完美。 为了稍微改善此解决方案,您可以将长类型定义移至功能接口

class Example {
    @FunctionalInterface
    private interface Callback extends GenericFutureListener<Future<String>> {
        void operationComplete(Future<String> future) throws Exception;
    }

    private static void callback(Future<String> future) {
        System.out.println(future.getNow());
    }

    public static void main(String[] args) {
        asyncMethod().addListener((Callback) Example::callback);
    }
}

或者您可以使用类型化的参数将回调包装到lambda

asyncMethod().addListener((Future<String> f) -> callback(f));

IDK,也许可以做得更好。

您可以选择以下任一种:

  1. 使用lambda (比完整的匿名类短,但仍然不是最佳):

asyncMethod().addListener((GenericFutureListener<Future<String>>) future -> Application.callback(future))

  1. 将回调的参数固定为:

private static void callback(Future<? super String> future) {

从简单的Future<String> future ,您也可以使用回调方法。

注意:如果您对? extends vs ? super ? extends vs ? super ? extends vs ? super泛型问题,出于同样的原因,我也为此贴了书签。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM