netty之Future和ChannelFuture

Netty框架采用异步IO模型,其中ChannelFuture是关键概念。执行如bind、write、connect等操作时,会返回一个ChannelFuture实例,而非立即返回结果。这允许开发者通过ChannelFuture检查操作状态,实现对异步操作的管理和监听。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在分析客户端是怎么连接服务端的和服务端怎么监听客户端请求前。很有必要熟悉netty框架整体思路,那么就不得不熟悉Future和ChannelFuture.

Netty中的异步,就不得不提ChannelFuture。Netty中的IO操作是异步的,包括bind、write、connect等操作会简单的返回一个ChannelFuture,调用者并不能立刻获得结果。


在Netty中的所有的I/O操作都是异步执行的,这就意味着任何一个I/O操作会立刻返回,不保证在调用结束的时候操作会执行完成。因此,会返回一个ChannelFuture的实例,通过这个实例可以获取当前I/O操作的状态。

ChannelFuture为完成或未完成状态。完成和未完成可对应的各种I/O操作结果如下所示

 *                                      + ---------------------------+
 *                                      | Completed successfully    |
 *                                      + ---------------------------+
 *                                 + ---->      isDone() = <b>true </b>      |
 * +--------------------------+    |    |   isSuccess() = <b>true</b>       |
 * |        Uncompleted       |    |    +===========================+
 * +--------------------------+    |    | Completed with failure    |
 * |      isDone() = <b>false</b>     |    |    +--------------------------- +
 * |   isSuccess() = false    | ----+---->    isDone() = <b>true </b>         |
 * | isCancelled() = false    |    |    | getCause() = <b>non- null</b>     |
 * |    getCause() = null     |    |    +===========================+
 * +--------------------------+    |    | Completed by cancellation |
 *                                 |    + ---------------------------+
 *                                 + ---->      isDone() = <b>true </b>      |
 *                                      | isCancelled() = <b>true</b>       |
 *                                      + ---------------------------+

通过ChannelFuture可以了解I/O操作的一些额外的详细信息。

当然,也提供了阻塞当前线程等待I/O执行结果的方法,就是awaitUninterruptibly 。

与这个接口紧密相关的是ChannelFutureListener,为特定的事项添加监听器。当事件发生时,会出发监听器指定相应的动作。

最后一点要指出调用await系列方法指定的等待超时时间和I/O超时时间之间是没有特定关系的。如果没有设置I/O超时时间,那么可能在await方法超时之后,future方法其实是没有执行完的。

作为一个异步NIO框架,Netty的所有IO操作都是异步非阻塞的,通过Future-Listener机制,用户可以方便的主动获取或者通过通知机制获得IO操作结果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值