点击上方[物联网思考],选择置顶,第一时间查看物联网分享!
前言:最近在做一个项目,需要把rssi传到平台,用于辅助判断硬件是否异常,rssi是负的,因此传到平台的数据要以有符号数来解析,平台那边对有符号、补码、位操作等比较模糊,因此有了本文。
1、基础知识
(1)负数在计算机中是以补码的形式存储的; (2)有符号数的最高位为1表示为负数,为0表示正数; (3)反码:等于原码除过符号位,其余位取反; (4)补码:等于反码加1。
2、以-62为例说明
下面以一个-62为例推导在计算机中的存储的数; 62对应的16进制为0x3E,转换成二进制 0011 1110,那么-62的: 原码为1011 1110, 反码为1100 0001, 补码为1100 0010,即就是0xC2,也就是-62在计算机中是以C2的形式存储的。
3、代码实现补码转换成原码
代码语言:javascript复制#include <stdio.h>
int main(void) {
unsigned char buma=0xc2;
unsigned char fanma=0;
signed char yuanma=0;
unsigned char index,temp=0;
printf("buma=%xrn",buma);
fanma=buma-1;
printf("fanma=%xrn",fanma);
for(index=0;index<7;index )
{
temp=fanma>>index;
temp=~temp;
temp&=0x01;
temp=temp<<index;
yuanma =temp;
}
if(fanma&0x80)
{
yuanma=-yuanma;
}
printf("yuanma=%drn",yuanma);
return 0;
}
推荐阅读:
二进制大文件(bin文件)如何快速转化为数组?