本文實(shí)例講述了C++實(shí)現(xiàn)string存取二進(jìn)制數(shù)據(jù)的方法,分享給大家供大家參考。具體方法分析如下:
一般來說,STL的string很強(qiáng)大,用起來也感覺很舒服,這段時(shí)間在代碼中涉及到了用string存取二進(jìn)制數(shù)據(jù)的問題,這里記錄一下,以供以后參考。
首先提一下STL中string的參考資料:http://www.cplusplus.com/reference/string/string/ ,不懂的朋友可以看下。
在數(shù)據(jù)傳輸中,二進(jìn)制數(shù)據(jù)的buffer一般用系統(tǒng)預(yù)設(shè)的大數(shù)組進(jìn)行存儲(chǔ),而不是STL的string等,比如:
const int max_length = 1024 * 1024;unsigned char data[max_length];
因?yàn)槎M(jìn)制數(shù)據(jù)中可能會(huì)包含0x00(即:'/0'),剛好是字符串結(jié)束標(biāo)志……
如果我們的代碼是如下寫的:
char data[max_length];size_t length = sockClient.read_some(boost::asio::buffer(data), ec);string strData(data);
我只能說,這個(gè)處理字符串應(yīng)該沒問題,如果是二進(jìn)制的話,會(huì)被string的構(gòu)造函數(shù)給截?cái)嘁徊糠郑瑢?dǎo)致strData和data的數(shù)據(jù)不一致。
其實(shí)一個(gè)簡(jiǎn)單的demo就可以說明問題,比如如下代碼:
#include <string>#include <iostream>using namespace std;int main(){ char data[] = {'A','b',0x00,'c','d'}; string str1(data),str2(data,sizeof(data)); cout<<str1<<endl; cout<<str1.size()<<endl; cout<<str2<<endl; cout<<str2.size()<<endl; return 0;}運(yùn)行效果如下:
Ab2Abcd5
從運(yùn)行結(jié)果不難發(fā)現(xiàn),采用str2的那種方式就可以保證string中的數(shù)據(jù)和原始data中的數(shù)據(jù)一致。這是因?yàn)椴捎貌煌臉?gòu)造函數(shù)不同,導(dǎo)致結(jié)構(gòu)完全不一樣,這個(gè)可以從我前面給出的網(wǎng)址中去查看具體的構(gòu)造函數(shù)說明加以理解。這里我們回到前面的那個(gè)問題,如果想保存二進(jìn)制的話,我們應(yīng)該如下操作:
char data[max_length];size_t length = sockClient.read_some(boost::asio::buffer(data), ec);string strData(data,length);
如果要取出數(shù)據(jù)的話,也簡(jiǎn)單(這個(gè)還以socket數(shù)據(jù)收發(fā)為例):
......// deal with strData......boost::asio::write(sockClient, boost::asio::buffer(strData.c_str(),strData.length()));
這里的strData.c_str()即為數(shù)據(jù),strData.length()即為要發(fā)送的數(shù)據(jù)長(zhǎng)度(當(dāng)然也可以使用strData.size()來操作)。
當(dāng)然,我們這里用string來存取二進(jìn)制數(shù)據(jù),也只是為了操作方便,感覺這個(gè)不是太好,應(yīng)該會(huì)有很多朋友不提倡這種做法的,這里提供一個(gè)思路,大家覺得好就采用,覺得不好就一笑了之,呵呵……
希望本文所述對(duì)大家的C++程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答