Netty编解码操作步骤详细解析是怎样的?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1294个文字,预计阅读时间需要6分钟。
前言:何为编码,通俗的来讲,我们需要将一段文本信息从A点发送到B点,并且将这段文本信息进行加工处理,例如:A将信息文本编码为2进制信息进行传输。B接收到的消息是一段2进制信息,需要解码。
前言
何为编解码,通俗的来说,我们需要将一串文本信息从A发送到B并且将这段文本进行加工处理,如:A将信息文本信息编码为2进制信息进行传输。B接受到的消息是一串2进制信息,需要将其解码为文本信息才能正常进行处理。
上章我们介绍的Netty如何解决拆包和粘包问题,就是运用了解码的这一功能。
java默认的序列化机制
使用Netty大多是java程序猿,我们基于一切都是对象的原则,经常会将对象进行网络传输,那么对于序列化操作肯定大家都是非常熟悉的。
一个对象是不能直接进行网络I/O传输的,jdk默认是将对象转换为可存储的字节数组来进行网络操作。基于JDK默认的序列化机制可以避免操作底层的字节数组,从而提升开发效率。
jdk默认的序列化机制虽然能给程序猿带来极大的方便,但是它也带来了许多问题:
- 无法跨语言。
- 序列化后的码流太大,会给网络传输带来极大的开销。
- 序列化的性能太低,对于高性能的网络架构是极其不友好的。
主流的编解码框架
- Google的Protobuf。
- Facebok的Thrift。
本文共计1294个文字,预计阅读时间需要6分钟。
前言:何为编码,通俗的来讲,我们需要将一段文本信息从A点发送到B点,并且将这段文本信息进行加工处理,例如:A将信息文本编码为2进制信息进行传输。B接收到的消息是一段2进制信息,需要解码。
前言
何为编解码,通俗的来说,我们需要将一串文本信息从A发送到B并且将这段文本进行加工处理,如:A将信息文本信息编码为2进制信息进行传输。B接受到的消息是一串2进制信息,需要将其解码为文本信息才能正常进行处理。
上章我们介绍的Netty如何解决拆包和粘包问题,就是运用了解码的这一功能。
java默认的序列化机制
使用Netty大多是java程序猿,我们基于一切都是对象的原则,经常会将对象进行网络传输,那么对于序列化操作肯定大家都是非常熟悉的。
一个对象是不能直接进行网络I/O传输的,jdk默认是将对象转换为可存储的字节数组来进行网络操作。基于JDK默认的序列化机制可以避免操作底层的字节数组,从而提升开发效率。
jdk默认的序列化机制虽然能给程序猿带来极大的方便,但是它也带来了许多问题:
- 无法跨语言。
- 序列化后的码流太大,会给网络传输带来极大的开销。
- 序列化的性能太低,对于高性能的网络架构是极其不友好的。
主流的编解码框架
- Google的Protobuf。
- Facebok的Thrift。

