工作的时候遇到一个问题,需要把一个存储二进制网络流的buff转化为一个字符串进行存储。在网上搜了半天看到的方法都比较复杂。
在这里介绍一种自己认为比较简便的方法。
二进制网络流一般都是unsigned char类型。跟char的区别在于读取的方式不同,但是存储
的位数并没有什么不同。假设unsigned char Buff[] 里存储了二进制的网络流,在这里我们可以先使用char *NewBuff = (char*)Buff进行强制转换。
接下来就是由字符串转化为string就可以了。但是有个问题,在生成string的时候,string会复制buff中的字符直到遇到\0 的字符。
大家可以来看看构造一个string的代码实现:
-
inline String::String(const char* str)
-
{
-
if(!str)m_data=0;
-
else {
-
m_data=new char[strlen(str)+1];
-
strcpy(m_data,str);
-
}
-
}
传入的buf会由strlen来计算长度,我们再来看看strlen的实现:
int strlen(const char *str)
{
assert(str != NULL);
int len = 0;
while((*str++) != '\0')
len++;
return len;
}
大家可以看到,strlen遇到\0 就认为字符已经到结尾了。假设我们的Buff 存储的网络流里头包含\0,那么NewBuff被strlen
计算长度的时候,遇到\0就停止了。导致Buff在\0后面的字符都没有计算在内,最后生成的字符串就是\0前面的部分,这就造成了
信息丢失。在这里我们需要在处理网络收包的时候通过某些方法知道我们这个buff的长度,然后调用string::assign(char*,size_t n)
指定buff拷贝的长度,这样子buff中的内容都会被拷贝到string里头。不会造成数据的丢失。将string取出来再进行逆向的
转换就可以了。大家可以验证下。
如果有写得不对的地方欢迎批评指正。你的批评就是对我的最大的帮助。
阅读(6282) | 评论(0) | 转发(0) |