varint - int32数据编码解码C程序实现

原创 2016年06月01日 11:19:31
#include <stdio.h>

/************************************************

*说明:下面代码没有纠错部分。

*请自行添加。

*******************************************************/



int Variant_Encode()
{

          unsigned char data[5]={0} ;
          int count = 0;
          int value=300;
          do
          {
              data[count] = (unsigned char )((value & 0x7F) | 0x80);
              count++;
          } while ((value >>= 7) != 0);
          data[count - 1] &= 0x7F;
        printf("data=%x,%x,%x,%x,%x\n",data[0],data[1],data[2],data[3],data[4]);

        return 0;

}

/*************************************华丽的分割线************************************/
unsigned int Variant_Decode ( )
{
        unsigned char data[5]={ 0xac,0x02,0x00,0x00,0x00 };
        unsigned int value = data[0];
        if ((value & 0x80) == 0) return value;
        value &= 0x7F;
        unsigned int chunk = data[1];
        value |= (chunk & 0x7F) << 7;
        if ((chunk & 0x80) == 0) return value;
        chunk = data[2];
        value |= (chunk & 0x7F) << 14;
        if ((chunk & 0x80) == 0) return value;
        chunk = data[3];
        value |= (chunk & 0x7F) << 21;
        if ((chunk & 0x80) == 0) return value;
        chunk = data[4]; ;
        value |= chunk << 28;
        if ((chunk & 0xF0) == 0) return value;

}




版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

图解Protobuf编码

图解Protobuf编码Protobuf是Google发布的消息序列化工具。Protobuf定义了消息描述语法(proto语法)和消息编码格式,并且提供了主流语言的代码生成器(protoc)。本文仅讨...

Protocol Buffers编码详解,例子,图解

Protocol Buffers编码详解,例子,图解 本文不是让你掌握protobuf的使用,而是以超级细致的例子的方式分析protobuf的编码设计。通过此文你可以了解protobuf的数据压缩能力...

精选:深入理解 Docker 内部原理及网络配置

网络绝对是任何系统的核心,对于容器而言也是如此。Docker 作为目前最火的轻量级容器技术,有很多令人称道的功能,如 Docker 的镜像管理。然而,Docker的网络一直以来都比较薄弱,所以我们有必要深入了解Docker的网络知识,以满足更高的网络需求。

C++ 使用ProtoBuffer 心得

C++ 如何 把本地字符转换成 protoBuffer数据。反向如何把 protoBUffer 转成本地字符串。

[C]lexcode数据包编/解码程序

byAlex Jan2013 GNU GCC编译测试 lexcode数据包编码解码程序,用于编/解码简短的数据或指令,方便通信。 最多携带32KB数据,可以划分为127个参数。lexcode数据包...

varint-levelDB源码解析

【什么是变长整型?】 大家知道,int整型一般是4个字节,那变长整型所需要的空间在1-5个字节之间,因为长度是不固定的,所以称之为变长整型。其特点就是只要数值小于2^21,那么就会节省空间。 【编...

Base64编码解码C语言实现

static const char *codes = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; ...

BASE64编码and解码的C实现

#include "stdio.h" #include "string.h" static char base64_encode_map[] = "ABCDEFGHIJKLMNOPQRSTUVWXY...

C#实现Base64编码与解码

一、编码规则       Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码。它将需要编码的数据拆分成字节数组。以3个字节为一组。按顺序排列24 位数据,再把这...

用C++实现Base64编码解码

Base64编码解码实现string Base64::EncodeBase64(char const * sourcebuf,int buflen) { string ret; uns...

base64 编码解码 c语言实现

#include #include #include char *base64_encode(const char *src); char *base64_decode(const char ...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)