国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > C++ > 正文

如何在C++中實(shí)現(xiàn)按位存取

2020-01-26 15:00:59
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

在我創(chuàng)業(yè)的一個(gè)項(xiàng)目中,為了節(jié)約網(wǎng)絡(luò)帶寬,因此在網(wǎng)絡(luò)中傳輸數(shù)據(jù)需要實(shí)現(xiàn)緊湊存取,在國(guó)防,科研,航天,軍工等多個(gè)領(lǐng)域其實(shí)也有類(lèi)似的需求。
實(shí)現(xiàn)緊湊存取,不是按一個(gè)字節(jié)一個(gè)字節(jié)地存取,而是按位存取。比如一個(gè)字節(jié),我們可以存儲(chǔ)8個(gè)bool信息,廢話少說(shuō),直接分享代碼(備注:里面的代碼算法值得優(yōu)化)。

//以下為函數(shù)定義 

/***********************************************************************/ /*  函數(shù)作用:從buffer讀一個(gè)位                    */ /*  參數(shù)pBuffer[in]:指定buffer                    */ /*  參數(shù)nStart[in]:指定位置                     */ /*  參數(shù)nEnd[out]:返回結(jié)束位置                    */ /*  參數(shù)retByte[out]:返回讀取結(jié)果值                 */ /*  返回:void                              */ /***********************************************************************/ void ReadOneBit( byte* pBuffer, int nStart, /* out */int& nEnd, /* out */ byte& retByte );  /***********************************************************************/ /*  函數(shù)作用:從指定buffer里讀任意一段位置數(shù)據(jù)            */ /*  參數(shù)pBuffer[in]:指定buffer                    */ /*  參數(shù)nStart[in]:指定位置                     */ /*  參數(shù)btLength[in]:讀取長(zhǎng)度                    */ /*  參數(shù)nEnd[out]:返回結(jié)束位置                    */ /*  參數(shù)retData[out]:返回讀取結(jié)果值,支持任意數(shù)據(jù)類(lèi)型        */ /*  返回:void                              */ /***********************************************************************/ template<typename T> void ReadDataFromBuffer( byte* pBuffer, int nStart, byte btLength, /* out */int& nEnd, /* out */ T& retData );  /***********************************************************************/ /*  函數(shù)作用:從指定buffer里讀取一段字符串              */ /*  參數(shù)pBuffer[in]:指定buffer                    */ /*  參數(shù)nStart[in]:指定位置                     */ /*  參數(shù)nCount[in]:字符串長(zhǎng)度                    */ /*  參數(shù)nEnd[out]:返回結(jié)束位置                    */ /*  參數(shù)pRetData[out]:返回讀取字符串結(jié)果               */ /*  返回:void                              */ /***********************************************************************/ void ReadStringFromBuffer( byte* pBuffer, int nStart, int nCount, /* out */int& nEnd, /* out */char* pRetData );    /***********************************************************************/ /*  函數(shù)作用:向buffer寫(xiě)一個(gè)位                    */ /*  參數(shù)pBuffer[in]:指定buffer                    */ /*  參數(shù)btData[in]:需要寫(xiě)入的值                   */ /*  參數(shù)nStart[in]:指定位置                     */ /*  參數(shù)nEnd[out]:返回結(jié)束位置                    */ /*  返回:void                              */ /***********************************************************************/ void WriteOneBit( byte* pBuffer, byte btData, int nStart, /* out */int& nEnd );  /***********************************************************************/ /*  函數(shù)作用:向指定buffer里寫(xiě)入任意一段數(shù)據(jù)             */ /*  參數(shù)pBuffer[in]:指定buffer                    */ /*  參數(shù)tData[in]:需要寫(xiě)入的數(shù)據(jù),支持任意數(shù)據(jù)類(lèi)型          */ /*  參數(shù)nStart[in]:指定位置                     */ /*  參數(shù)btLength[in]:讀取長(zhǎng)度                    */ /*  參數(shù)nEnd[out]:返回結(jié)束位置                    */ /*  返回:void                              */ /***********************************************************************/ template<typename T> void WriteDataToBuffer( byte* pBuffer, T tData, int nStart, byte btLength, /* out */int& nEnd );  /***********************************************************************/ /*  函數(shù)作用:向指定buffer里寫(xiě)取一段字符串              */ /*  參數(shù)pBuffer[in]:指定buffer                    */ /*  參數(shù)pchar[in]:需要寫(xiě)入的字符串                  */ /*  參數(shù)nStart[in]:指定位置                     */ /*  參數(shù)nCount[in]:字符串長(zhǎng)度                    */ /*  參數(shù)nEnd[out]:返回結(jié)束位置                    */ /*  返回:void                              */ /***********************************************************************/ void WtriteStringToBuffer( byte* pBuffer, char* pchar, int nStart, int nCount, /* out */int& nEnd ); 


//以下為函數(shù)實(shí)現(xiàn)

void ReadOneBit( byte* pBuffer, int nStart, /* out */int& nEnd, /* out */ byte& retByte ) {   byte btData = pBuffer[nStart/8];   btData = btData << nStart%8;   retByte = btData >> 7;   nEnd = nStart+1; }  template<typename T> void ReadDataFromBuffer( byte* pBuffer, int nStart, byte btLength, /* out */int& nEnd, /* out */ T& retData ) {   //順序讀位   retData = 0;   if ( btLength > sizeof(T)*8 )     return ;      byte btData;   T tData;   while ( btLength-- )   {     ReadOneBit(pBuffer, nStart, nStart, btData);     tData = btData << btLength;     retData |= tData;   }      nEnd = nStart; }  void ReadStringFromBuffer( byte* pBuffer, int nStart, int nCount, /* out */int& nEnd, /* out */char* pRetData ) {   for ( int nIndex=0; nIndex<nCount; nIndex++ )   {     ReadDataFromBuffer(pBuffer, nStart, 8, nStart, pRetData[nIndex]);   }   nEnd = nStart; }   void WriteOneBit( byte* pBuffer, byte btData, int nStart, /* out */int& nEnd ) {   int nSet = nStart / 8;   byte c = pBuffer[nSet];   switch ( btData )   {   case 1:     c |= ( 1 << (7- nStart % 8) );     break;   case 0:     c &= ( ~(1 << (7- nStart % 8) ) );     break;   default:     return;   }   pBuffer [nSet] = c;   nEnd = nStart +1; }    template<typename T> void WriteDataToBuffer( byte* pBuffer, T tData, int nStart, byte btLength, /* out */int& nEnd ) { /* //大端機(jī)模式   byte btDataLength = sizeof(T);   if ( btLength > sizeof(T)*8 )     return;      int nDataStart = 0; //數(shù)據(jù)的第一位位置為0,順序?qū)懭?  while ( btLength-- )   {     byte bitData;     ReadOneBit((byte*)&tData, nDataStart, nDataStart, bitData);     WriteOneBit(pBuffer, bitData, nStart, nStart);   }      nEnd = nStart; */    //小端機(jī)模式:寫(xiě)buffer的時(shí)候,不能順序?qū)懳?   //獲得模版占用字節(jié)大小   byte btDataLength = sizeof(T);    //校驗(yàn)長(zhǎng)度是否越界   if ( btLength > sizeof(T)*8 )     return;    //將待寫(xiě)數(shù)據(jù)轉(zhuǎn)為byte*   byte* ptData = (byte*)&tData;     //求模與余   int nSet = btLength / 8;   int nRin = btLength % 8;      //定義字節(jié)數(shù)據(jù)與位數(shù)據(jù)   byte bitData;   byte byteData;   int nTempEnd;    //先寫(xiě)rin數(shù)據(jù)   byteData = ptData[nSet];   while ( nRin-- )   {     ReadOneBit(&byteData, 7-nRin, nTempEnd, bitData);     WriteOneBit(pBuffer, bitData, nStart, nStart);   }    //再寫(xiě)Set數(shù)據(jù)   while ( nSet )   {     byteData = ptData[--nSet];     //寫(xiě)一個(gè)byte     int i=0;     while ( i!=8 )     {       ReadOneBit(&byteData, i++, nTempEnd, bitData);       WriteOneBit(pBuffer, bitData, nStart, nStart);     }   }   nEnd = nStart;  }   void WtriteStringToBuffer( byte* pBuffer, char* pchar, int nStart, int nCount, /* out */int& nEnd ) {   for ( int nIndex=0; nIndex<nCount; nIndex++ )   {     WriteDataToBuffer(pBuffer, pchar[nIndex], nStart, 8, nStart);   }   nEnd = nStart; } 

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 比如县| 上虞市| 罗源县| 彭泽县| 兰考县| 嘉祥县| 赤水市| 浦北县| 松滋市| 泸水县| 荆州市| 二手房| 曲阜市| 合江县| 昌吉市| 南京市| 兰溪市| 伽师县| 晋江市| 济源市| 调兵山市| 长汀县| 瑞丽市| 海阳市| 武乡县| 富裕县| 临高县| 财经| 南城县| 江津市| 墨玉县| 集贤县| 哈尔滨市| 汶上县| 红安县| 体育| 长阳| 治县。| 宾阳县| 凉城县| 永胜县|