(转载自:http://asialee.iteye.com/blog/1784844)
在使用这个decoder的时候,经常要考虑参数如何设置,如果7种case基本上把应用场景都涵盖了。
- 第一种情况:从lenght从头开始,长度为2,不跳过头部
- lengthFieldOffset = 0
- lengthFieldLength = 2
- lengthAdjustment = 0
- initialBytesToStrip = 0 (= do not strip header)
- BEFORE DECODE (14 bytes) AFTER DECODE (14 bytes)
- +--------+----------------+ +--------+----------------+
- | Length | Actual Content |----->| Length | Actual Content |
- | 0x000C | "HELLO, WORLD" | | 0x000C | "HELLO, WORLD" |
- +--------+----------------+ +--------+----------------+
- 第二种情况,从length从头开始,长度为2,跳过头部
- lengthFieldOffset = 0
- lengthFieldLength = 2
- lengthAdjustment = 0
- initialBytesToStrip = 2 (= the length of the Length field)
- BEFORE DECODE (14 bytes) AFTER DECODE (12 bytes)
- +--------+----------------+ +----------------+
- | Length | Actual Content |----->| Actual Content |
- | 0x000C | "HELLO, WORLD" | | "HELLO, WORLD" |
- +--------+----------------+ +----------------+
这个和上面的区别是,数据经过解码后头部被去掉了
- 第三种情况,2个字节长度的头部,offset是0,但是长度代表的是整个数据帧的长度,即就是包含头部
- lengthFieldOffset = 0
- lengthFieldLength = 2
- lengthAdjustment = -2 (= the length of the Length field)
- initialBytesToStrip = 0
- BEFORE DECODE (14 bytes) AFTER DECODE (14 bytes)
- +--------+----------------+ +--------+----------------+
- | Length | Actual Content |----->| Length | Actual Content |
- | 0x000E | "HELLO, WORLD" | | 0x000E | "HELLO, WORLD" |
- +--------+----------------+ +--------+----------------+
- 第四种情况,5个字节长度的头部,但是数据帧的lenght的字节数是3,offset是2,不跳过头部
- lengthFieldOffset = 2 (= the length of Header 1)
- lengthFieldLength = 3
- lengthAdjustment = 0
- initialBytesToStrip = 0
- BEFORE DECODE (17 bytes) AFTER DECODE (17 bytes)
- +----------+----------+----------------+ +----------+----------+----------------+
- | Header 1 | Length | Actual Content |----->| Header 1 | Length | Actual Content |
- | 0xCAFE | 0x00000C | "HELLO, WORLD" | | 0xCAFE | 0x00000C | "HELLO, WORLD" |
- +----------+----------+----------------+ +----------+----------+----------------+
- 第五种情况,5个字节长度的头部,但是数据帧的lenght的字节数是3,offset是0,不跳过头部
- lengthFieldOffset = 0
- lengthFieldLength = 3
- lengthAdjustment = 2 (= the length of Header 1)
- initialBytesToStrip = 0
- BEFORE DECODE (17 bytes) AFTER DECODE (17 bytes)
- +----------+----------+----------------+ +----------+----------+----------------+
- | Length | Header 1 | Actual Content |----->| Length | Header 1 | Actual Content |
- | 0x00000C | 0xCAFE | "HELLO, WORLD" | | 0x00000C | 0xCAFE | "HELLO, WORLD" |
- +----------+----------+----------------+ +----------+----------+----------------+
这个稍微解释一下,由于我们的头部是5个字节,但是length数据域只有3个字节,所以lengthAdjustment是2,表明需要2个字节来调整整个帧的长度。
- 第六种情况,4个字节长度的头部,但是数据帧的lenght的字节数是2,offset是1,跳过头部第一个数据域和长度域
- lengthFieldOffset = 1 (= the length of HDR1)
- lengthFieldLength = 2
- lengthAdjustment = 1 (= the length of HDR2)
- initialBytesToStrip = 3 (= the length of HDR1 + LEN)
- BEFORE DECODE (16 bytes) AFTER DECODE (13 bytes)
- +------+--------+------+----------------+ +------+----------------+
- | HDR1 | Length | HDR2 | Actual Content |----->| HDR2 | Actual Content |
- | 0xCA | 0x000C | 0xFE | "HELLO, WORLD" | | 0xFE | "HELLO, WORLD" |
- +------+--------+------+----------------+ +------+----------------+
这个我稍微解释一下,HDR1是一个字节,Lenght是2个字节,HDR2是两个字节,解码后需要包含HDR2,所以lenghtFieldOffset是1,lenghtFieldLenght是2,lenghtAdjustment是1,实际上就是HDR2的长度,initailBytesToStrip是3,实际上就是HDR1+LEN的长度。
- 第七种情况,4个字节长度的头部,但是数据帧的lenght的字节数是2,offset是1,跳过头部第一个数据域和长度域,消息的长度代表整个数据帧的长度
- lengthFieldOffset = 1
- lengthFieldLength = 2
- lengthAdjustment = -3 (= the length of HDR1 + LEN, negative)
- initialBytesToStrip = 3
- BEFORE DECODE (16 bytes) AFTER DECODE (13 bytes)
- +------+--------+------+----------------+ +------+----------------+
- | HDR1 | Length | HDR2 | Actual Content |----->| HDR2 | Actual Content |
- | 0xCA | 0x0010 | 0xFE | "HELLO, WORLD" | | 0xFE | "HELLO, WORLD" |