7bit编码

// 7-bit解码
// pSrc: 源编码串指针
// pDst: 目标字符串指针
// nSrcLength: 源编码串长度
// 返回: 目标字符串长度
int gsmDecode7bit(const unsigned char* pSrc, char* pDst, int nSrcLength)
{
  int nSrc; // 源字符串的计数值
  int nDst; // 目标解码串的计数值
  int nByte; // 当前正在处理的组内字节的序号,范围是0-6
  unsigned char nLeft; // 上一字节残余的数据
   
  // 计数值初始化
  nSrc = 0;
  nDst = 0;
   
  // 组内字节序号和残余数据初始化
  nByte = 0;
  nLeft = 0;
   
  // 将源数据每7个字节分为一组,解压缩成8个字节
  // 循环该处理过程,直至源数据被处理完
  // 如果分组不到7字节,也能正确处理
  while(nSrc<nSrcLength)
  {
  // 将源字节右边部分与残余数据相加,去掉最高位,得到一个目标解码字节
  *pDst = ((*pSrc << nByte) | nLeft) & 0x7f;
  // 将该字节剩下的左边部分,作为残余数据保存起来
  nLeft = *pSrc >> (7-nByte);
   
  // 修改目标串的指针和计数值
  pDst++;
  nDst++;
   
  // 修改字节计数值
  nByte++;
   
  // 到了一组的最后一个字节
  if(nByte == 7)
  {
  // 额外得到一个目标解码字节
  *pDst = nLeft;
   
  // 修改目标串的指针和计数值
  pDst++;
  nDst++;
   
  // 组内字节序号和残余数据初始化
  nByte = 0;
  nLeft = 0;
  }
   
  // 修改源串的指针和计数值
  pSrc++;
  nSrc++;
  }
   
  *pDst = 0;
   
  // 返回目标串长度
  return nDst;
}

========================================================
怎么调用它?
可以取得代码是 4A

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值