简介
字符串是我们程序中最常用到的消息格式,也是最简单的消息格式,但是正因为字符串 string 太过简单,不能附加更多的信息,所以在 netty 中选择的是使用 byteBuf 作为最底层的消息传递载体。
虽然底层使用的 ByteBuf,但是对于程序员来说,还是希望能够使用这种最简单的字符串格式,那么有什么简单的方法吗?
以下Java面试题是今年最新的,需要的小伙伴可以后台撩我拿 关键词 “免费”? 即可!
netty 中的字符串编码解码器
为了解决在 netty 的 channel 中传递字符串的问题,netty 提供了针对于字符串的编码和解码器,分别是 StringEncoder 和 StringDecoder。
我们来看下他们是怎么在程序中使用的,首先是将 StringDecoder 和 StringEncoder 加入 channelPipeline 中:
ChannelPipeline pipeline = ...;
// Decoders
pipeline.addLast("frameDecoder", new LineBasedFrameDecod