基础篇走进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));