future promise java_Netty 中的 ChannelPromise 具体是做什么用的?

最近一直在学习Netty,不明白ChannelPromise具体是做什么用的

我使用的Netty是4.0.0.Final版本,其中ChannelOutboundHandler接口的部分定义:

public interface ChannelOutboundHandler extends ChannelHandler {

/**

* Called once a write operation is made. The write operation will write the messages through the

* {@link ChannelPipeline}. Those are then ready to be flushed to the actual {@link Channel} once

* {@link Channel#flush()} is called

*

* @param ctx the {@link ChannelHandlerContext} for which the write operation is made

* @param msg the message to write

* @param promise the {@link ChannelPromise} to notify once the operation completes

* @throws Exception thrown if an error accour

*/

void write(ChannelHandlerContext ctx, Object msg, ChannelPromise promise) throws Exception;

//其他的方法..

}

Promise继承了Future,我对Future有一定了解:Future可以保存在将来计算出的结果或错误,可以通过Future实例来判断是否计算完成、阻塞等待结果、取消、注册监听器之类的

这里的Promise和Future有什么区别?具体到Netty中,如何使用?比如上面的write方法?

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值