Netty杂项

博客围绕Netty展开,介绍了Promise和Future这对实现异步的重要组件,二者分工明确、成对出现,能提高CPU利用率。还阐述了Netty对其的扩展及Channel相关内容。此外,讲解了TCP黏包和拆包问题、解决方法、编码解码技术,以及Netty中的编解码框架和开发方式。

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

双子星Promise和Future

作用:是实现异步非常重要的一环;也使无锁化串行的实现变得可控,channel中的线程谁先完成无所谓,拿到结果进行回调这一步控制好即可。这样能大大提高CPU利用率

流程、分工::线程不断地与Promise交互,线程执行完之后,Promise通知Future,Future来决定调用哪个回调方法;两者必须成对出现,Promise保存线程执行状态,用来通知Future;Future负责注册跟回调
在这里插入图片描述

1.Future

在这里插入图片描述
扩展了Future接口,其重要方法为:isSuccess、addListener、sync、await等,为JDK中拥有的,addListener就是用来做回调的;运行在前端层面

2.Promise

也扩展了Future接口,其重要方法如addListener等是类似的,表示一种可写的Future,即可以设置异步执行的结果;运行在后端层面

3.Netty进行的扩展

ChannelPromise:
在这里插入图片描述

4.Channel生命周期:

在这里插入图片描述

5.ChannelHandler及其子类

Handler类继承图
在这里插入图片描述
方法:
在这里插入图片描述

5.1 ChannelInboundHandler

在这里插入图片描述

数据翻译官:编码和解码

1 TCP黏包和拆包

发生在TCP底层
在这里插入图片描述

2 黏包问题的解决方法

在这里插入图片描述
第二种方式一般只适合于文本内容

第四种的原理为1、2、3中的一种,规则更复杂了而已

3 编码解码技术

在这里插入图片描述
编码器:拆包工具;解码器:黏包工具

4 Netty中的编解码框架

为什么需要?
在这里插入图片描述
如何开发?

如果熟悉Netty底层,则直接使用ChannelHandler扩展开发;如果不熟悉,Netty也提供了通用的编解码框架供用户扩展,也提供了常用的编解码类库供用户直接使用,如base64、Protobuf、JBoss、Marshalling、spdy等
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值