补码(负数)转换成原码

2021-08-20 10:55:26 浏览数 (1)

点击上方[物联网思考],选择置顶,第一时间查看物联网分享!

前言:最近在做一个项目,需要把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文件)如何快速转化为数组?

0 人点赞