• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 如何在C++中实现按位存取

如何在C++中实现按位存取

作者:VeiwoZouhui 字体:[增加 减小] 来源:互联网 时间:2017-05-28

VeiwoZouhui 通过本文主要向大家介绍了c++2005 32位,c++2005 64位,c++2008 64位,c++2008 32位,c++2012 64位等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

在我创业的一个项目中,为了节约网络带宽,因此在网络中传输数据需要实现紧凑存取,在国防,科研,航天,军工等多个领域其实也有类似的需求。
实现紧凑存取,不是按一个字节一个字节地存取,而是按位存取。比如一个字节,我们可以存储8个bool信息,废话少说,直接分享代码(备注:里面的代码算法值得优化)。

//以下为函数定义 

/***********************************************************************/ 
/*  函数作用:从buffer读一个位                    */ 
/*  参数pBuffer[in]:指定buffer                    */ 
/*  参数nStart[in]:指定位置                     */ 
/*  参数nEnd[out]:返回结束位置                    */ 
/*  参数retByte[out]:返回读取结果值                 */ 
/*  返回:void                              */ 
/***********************************************************************/ 
void ReadOneBit( byte* pBuffer, int nStart, /* out */int& nEnd, /* out */ byte& retByte ); 
 
/***********************************************************************/ 
/*  函数作用:从指定buffer里读任意一段位置数据            */ 
/*  参数pBuffer[in]:指定buffer                    */ 
/*  参数nStart[in]:指定位置                     */ 
/*  参数btLength[in]:读取长度                    */ 
/*  参数nEnd[out]:返回结束位置                    */ 
/*  参数retData[out]:返回读取结果值,支持任意数据类型        */ 
/*  返回:void                              */ 
/***********************************************************************/ 
template<typename T> 
void ReadDataFromBuffer( byte* pBuffer, int nStart, byte btLength, /* out */int& nEnd, /* out */ T& retData ); 
 
/***********************************************************************/ 
/*  函数作用:从指定buffer里读取一段字符串              */ 
/*  参数pBuffer[in]:指定buffer                    */ 
/*  参数nStart[in]:指定位置                     */ 
/*  参数nCount[in]:字符串长度                    */ 
/*  参数nEnd[out]:返回结束位置                    */ 
/*  参数pRetData[out]:返回读取字符串结果               */ 
/*  返回:void                              */ 
/***********************************************************************/ 
void ReadStringFromBuffer( byte* pBuffer, int nStart, int nCount, /* out */int& nEnd, /* out */char* pRetData ); 
 
 
 
/***********************************************************************/ 
/*  函数作用:向buffer写一个位                    */ 
/*  参数pBuffer[in]:指定buffer                    */ 
/*  参数btData[in]:需要写入的值                   */ 
/*  参数nStart[in]:指定位置                     */ 
/*  参数nEnd[out]:返回结束位置                    */ 
/*  返回:void                              */ 
/***********************************************************************/ 
void WriteOneBit( byte* pBuffer, byte btData, int nStart, /* out */int& nEnd ); 
 
/***********************************************************************/ 
/*  函数作用:向指定buffer里写入任意一段数据             */ 
/*  参数pBuffer[in]:指定buffer                    */ 
/*  参数tData[in]:需要写入的数据,支持任意数据类型          */ 
/*  参数nStart[in]:指定位置                     */ 
/*  参数btLength[in]:读取长度                    */ 
/*  参数nEnd[out]:返回结束位置                    */ 
/*  返回:void                              */ 
/***********************************************************************/ 
template<typename T> 
void WriteDataToBuffer( byte* pBuffer, T tData, int nStart, byte btLength, /* out */int& nEnd ); 
 
/***********************************************************************/ 
/*  函数作用:向指定buffer里写取一段字符串              */ 
/*  参数pBuffer[in]:指定buffer                    */ 
/*  参数pchar[in]:需要写入的字符串                  */ 
/*  参数nStart[in]:指定位置                     */ 
/*  参数nCount[in]:字符串长度                    */ 
/*  参数nEnd[out]:返回结束位置                    */ 
/*  返回:void                              */ 
/***********************************************************************/ 
void WtriteStringToBuffer( byte* pBuffer, char* pchar, int nStart, int nCount, /* out */int& nEnd ); 
</div>


//以下为函数实现

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 ) 
{ 
/* //大端机模式 
  byte btDataLength = sizeof(T); 
  if ( btLength > sizeof(T)*8 ) 
    return; 
   
  int nDataStart = 0; //数据的第一位位置为0,顺序写入 
  while ( btLength-- ) 
  { 
    byte bitData; 
    ReadOneBit((byte*)&tData, nDataStart, nDataStart, bitData); 
    WriteOneBit(pBuffer, bitData, nStart, nStart); 
  } 
   
  nEnd = nStart; 
*/ 
 
  //小端机模式:写buffer的时候,不能顺序写位 
 
  //获得模版占用字节大小 
  byte btDataLength = sizeof(T); 
 
  //校验长度是否越界 
  if ( btLength > sizeof(T)*8 ) 
    return; 
 
  //将待写数据转为byte* 
  byte* ptData = (byte*)&tData;  
 
  //求模与余 
  int nSet = btLength / 8; 
  int nRin = btLength % 8; 
   
  //定义字节数据与位数据 
  byte bitData; 
  byte byteData; 
  int nTempEnd; 
 
  //先写rin数据 
  byteData = ptData[nSet]; 
  while ( nRin-- ) 
  { 
    ReadOneBit(&byteData, 7-nRin, nTempEnd, bitData); 
    WriteOneBit(pBuffer, bitData, nStart, nStart); 
  } 
 
  //再写Set数据 
  while ( nSet ) 
  { 
    byteData = ptData[--nSet]; 
    //写一个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; 
} 
</div>

以上就是本文的全部内容,希望对大家的学习有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 如何在C++中实现按位存取
  • C++位操作的常见用法小结

相关文章

  • 2017-05-28深入浅析C语言中堆栈和队列
  • 2017-05-28C++实现查找中位数的O(N)算法和Kmin算法
  • 2017-05-28C语言二维数组的处理实例
  • 2017-05-28详解C++文件读写操作
  • 2017-05-28linux下C语言中的mkdir函数与rmdir函数
  • 2017-05-28Cocos2d-x UI开发之CCControlColourPicker控件类使用实例
  • 2017-05-28C语言求幂计算的高效解法
  • 2017-05-28深入Windows下的回车是回车换行(\r\n)还是换行回车(\n\r)的详解
  • 2017-05-28C++对象的动态建立与释放详解
  • 2017-05-28C语言程序设计50例(经典收藏)

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C语言中的正负数及其输出
    • 类成员函数的重载、覆盖与隐藏之间的区别总结
    • C++ auto类型说明符
    • C语言数据结构中数制转换实例代码
    • 一波C语言二元查找树算法题目解答实例汇总
    • 对比C语言中memccpy()函数和memcpy()函数的用法
    • 最短路径问题Dijkstra算法学习
    • C++非递归建立二叉树实例
    • linux c多线程编程实例代码
    • C++中的重载、覆盖、隐藏介绍

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有