Netty权威指南

基础篇走进java NIO

第1章  java的I/O演进之路

1、I/O基础入门

2、java的I/O演进

第2章 NIO入门

第3章 Netty入门应用

时间服务器TimeServer和TimeClient开发、运行和调试

第4章 TCP 粘包/拆包问题的解决之道 

1、TCP 粘包/拆包问题说明

 2、TCP 粘包/拆包发生的原因

3、粘包问题的解决策略

4、利用LineBasedFrameDecoder和StringDecoder解决TCP 粘包问题 

LineBasedFrameDecoder:以换行符(“\n”或者“\r\n”)为结束标志的解码器,支持携带结束符或者不携带结束符两种解码方式,同时支持配置单行的最大长度。如果连续读取到最大长度后仍然没有发现换行符,会抛出异常,同时忽略掉之前读到的异常码流。

StringDecoder:将接受到的对象转换成字符串。

LineBasedFrameDecoder+StringDecoder组合是按行切换的文本解码器,它被设计用来支持TCP的粘包和拆包。

第5章 分隔符和定长解码器的应用

1、四种方式:

2、DelimiterBasedFrameDecoder:以分隔符做结束标志的消息的解码器(例:'$_')

3、FixedLengthFrameDecoder:固定长度的解码器

第6章 编解码技术 

 1、java序列化的特点:无法跨语言、序列化后的码流太大和序列化性能太低

注:网络传送数据都是二进制的

2、业界主流的编解码框架:Google 的Protobuf、Facebook 的Thrift和JBoss Marshalling

第7章 MessagePack 编解码

第8章 Google Protobuf 编解码

第9章 JBoss Marshalling 编解码

第10章 HTTP 协议开发应用

netty大小端:

在网络传输的过程中,字节存在俩种序列方式,即大端序和小端序。

举例来说,数值0x2211使用两个字节储存:高位字节是0x22,低位字节是0x11。

大端字节序:高位字节在前,低位字节在后,这是人类读写数值的方法。

小端字节序:低位字节在前,高位字节在后,即以0x1122形式储存。

咱们拿一个数字886来举例子:

888的二进制为:  【0000 0000】 【0000 0000】【0000 ‭0011】 【0111 1000】‬,以字节单位打印出来为: [0, 0, 3, 120] ,这种方式就是大端序。

如果按照小端序那么888的二进制为: ‭ 【0111 1000】‬  【0000 0011】 【0000 0000】【0000 0000】,以字节为单位打印出来为:[120, 3, 0, 0],这种方式就是小端序。

Netty大端序写入:[0, 0, 3, 120]

ByteBuf buf = ByteBufAllocator.DEFAULT.buffer(4);
buf.writeInt(888);
byte[] n = new byte[4];
System.out.println(buf.readBytes(n));
System.out.println(Arrays.toString(n));

Netty小端序写入:[120, 3, 0, 0]

ByteBuf buf = ByteBufAllocator.DEFAULT.buffer(4);
buf.writeIntLE(888);
byte[] n = new byte[4];
System.out.println(buf.readBytes(n));
System.out.println(Arrays.toString(n));

面试题:你要的Netty常见面试题总结,我面试回来整理好了!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值