关于TLV的排序有很多帖子,但是我觉得都写的不够仔细,今天研究了一天,写一篇尽量详细的帖子给大家,也作为自己日后复习。本帖的内容很多来 作者:Coder_Suo。原文:https://blog.csdn.net/u011846436/article/details/38588447
另外,文章中若有错误,希望大家批评指正。
题目背景描述: 消息(也称信息码流)的格式如下:
1、一条消息由1~128个基本信息单元(Information Element)IE组成。
2、每个IE采用TLV编码。TLV是Tag Length Value的缩写,它是一种变长数据的编解码, 由Tag,Length(Value的长度)及Value三个域组成。
3、Tag规定占4个字节(这只是本题的规定,也可以是2个字节),Length规定占2个字节(这只是本题的规定,也可以是1个字节),Value占几个字节由Length的值决定(例如Length=0x02,Value就占两个字节)。
4、字节存放按照小端方式(即高字节保存在高地址中)。
功能1:根据IE的Tag值大小对消息中所有的IE由小到大排序,并输出。
功能2:输出两个消息中相同IE的个数。
例如消息:0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x66
前面4个字节是Tag:0x00, 0x00, 0x00, 0x00
中间2个字节是Length:0x00, 0x02,
后面2个字节