TLV,全称是“type-length-value”,与“XML”、“Json”这些“字节流”格式不同,它是一种“二机制流”格式,不易阅读,但更省带宽,更容易压缩,常用于通信协议中的变长部分。


维基百科的定义如下:https://en.wikipedia.org/wiki/Type-length-value


一个TLV对象示例如下:


我的开源项目:一种TLV编解码器的实现_第1张图片 

 

多个TLV对象可以连接起来,组成一个大的buffer:


我的开源项目:一种TLV编解码器的实现_第2张图片

一个TLV对象内部也可以嵌套另一个TLV对象:


我的开源项目:一种TLV编解码器的实现_第3张图片


我希望能提供一套API接口(C/C++/Java/其他语言),可以方便地完成TLV格式的编码和解码,项目地址如下所示:


https://github.com/Jhuster/TLV


其中,C++版本已经实现(更新:C/Java/Android版本也均已实现),介绍如下:


1. TLV编码的接口


//put one TLV box
bool PutBoolValue(int type,bool value);
bool PutCharValue(int type,char value);
bool PutShortValue(int type,short value);
bool PutIntValue(int type,int value);
bool PutLongValue(int type,long value);
bool PutLongLongValue(int type,long long value);
bool PutFloatValue(int type,float value);
bool PutDoubleValue(int type,double value);
bool PutStringValue(int type,char *value);
bool PutStringValue(int type,const std::string &value);
bool PutBytesValue(int type,unsigned char *value,int length);
bool PutObjectValue(int type,const TlvBox& value);          

//do encode
bool Serialize(); 

//access encoded buffer and length
unsigned char * GetSerializedBuffer() const;
int GetSerializedBytes() const;


2. TLV解码的接口


//do decode
bool Parse(const unsigned char *buffer,int buffersize); 

//get one TLV box
bool GetBoolValue(int type,bool &value) const;
bool GetCharValue(int type,char &value) const;
bool GetShortValue(int type,short &value) const;
bool GetIntValue(int type,int &value) const;
bool GetLongValue(int type,long &value) const;
bool GetLongLongValue(int type,long long &value) const;
bool GetFloatValue(int type,float &value) const;
bool GetDoubleValue(int type,double &value) const;
bool GetStringValue(int type,char *value,int &length) const;
bool GetStringValue(int type,std::string &value) const;
bool GetBytesValue(int type,unsigned char *value,int &length) const;
bool GetBytesValuePtr(int type,unsigned char **value,int &length) const;
bool GetObjectValue(int type,TlvBox& value) const;


3. 具体用法


请参考代码目录下的 Test.cpp,有任何疑问欢迎来信[email protected]交流,提交issue,也欢迎为本项目贡献代码,谢谢。


欢迎大家关注我的新浪微博 @卢_俊 获取最新的文章和资讯。