首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

补码(负数)转换成原码

前言:最近在做一个项目,需要把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、代码实现补码转换成原码 #include int main(void) { unsigned char buma=0xc2; unsigned char fanma=

2.4K80
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    网络字节序与主机字节序的转换

    查看这些函数的解析,会发现这些函数其实是与主机字节序和网络字节序之间转换有关。就是什么网络字节序,什么是主机字节序呢?...时addrSrv.sin_addr.S_un.S_addr必须是赋值IP地址的网络字节序,htonl函数的作用是把一个主机字节序转换为网络字节序,也就是上面转换过程中第二步转换为第三步的作用,127.0.0.1...可见inet_addr函数的转换作用就是上面的第一步到第三步的转换。 下面再看端口的主机字节序与网络字节序的转换。以6000端口为例。...addrSrv.sin_port=htons(6000);可以直接写为 addrSrv.sin_port=28695;结果是一样的,htons的作用就是把端口号主机字节序转换为网络字节序。...二) UDP通信 (三) 网络字节序与主机字节序的转换 (四) TCP SOCKET recv的内存情况 (五) 异步套接字 (六) CAsyncSocket 与 CSocket 转载声明: 本文转自

    1.2K20

    字节序转换详解

    在跨平台和网络编程中我们经常会提到网络字节序和主机字节序,如果没有正确对两者进行转换,从而导致两方产生了不同的解释,就会出现意想不到的bug。...目录 0x01 概念 0x02 分类 0x03 两种字节序之间的区别 0x01 概念 字节序,就是大于一个字节类型的数据在内存中的存放顺序。...0x03 两种字节序之间的区别 通常我们的主机字节序是小端字节序,网络字节序是大端字节序,但是为什么要进行转换呢,如果不转换的话会发生什么,我们这里用一个不是很恰当的方式来解释一下。...虽然两者看起来仅仅只是存放的先后顺序不一样,但是如果不做相应的转换的话,将会导致所读取的数据完全不同 这里还拿上面的这个图来说 当我们使用小端方式来读的时候会出现下面这样的状况 ?...通过上面的这个方式便很容易的清楚了不重视两种存储方式而造成的后果 最后用网上的一个图来展示一下转换的传输过程 ?

    1.3K30

    网络字节序与主机字节序转换

    1.网络字节序与主机字节序 在Linux网络编程中,经常碰到网络字节序与主机字节序的相互转换。说到网络字节序与主机字节序需要清晰了解以下几个概念。 字节序,顾名思义,指字节在内存中存储的顺序。...比如一个int32_t类型的数值占用4个字节,这4个字节在内存中的排列顺序就是字节序。...下面以32位位宽数值0x12345678为例,小端字节序与大端字节序具体的存储区别如下所示: image.png 主机字节序,即CPU存储数据时采用的字节顺序。...网络字节顺序采用big endian排序方式。 2.网络字节序与主机字节序的相互转换 2.1常用系统调用 Linux socket网络编程中,经常会使用下面四个C标准库函数进行字节序间的转换。...类型从网络序转换到主机序 uint16_t ntohs(uint16_t netshort); //把uint16_t类型从网络序转换到主机序 2.2 64位数值的转换 现在如果需要对64位类型数据进行主机字节序与网络字节序的转换

    5.6K31

    Go: 负数转换uint64会是什么结果

    负数转换为uint64类型时会发生什么呢?在Go语言中,这样的转换并不会引发错误,但结果可能会令人意外。下面我们深入探讨这个问题。...负数转换为uint64的内部机制 当一个负整数转换为无符号整数(例如uint64)时,会使用该负整数的二进制补码表示。补码是一种特殊的二进制编码,用于表示负整数。...它允许我们使用相同的硬件进行加法和减法运算。 在二进制补码中,负数的最高位为1,其余位表示正整数部分的补码。因此,将负数转换为uint64将产生一个非常大的正整数。...注意事项 虽然在Go语言中,负数转换为uint64是合法的,但这样的转换可能会引入错误和混淆,特别是当该值用于后续计算时。...如果可能的话,最好避免这样的转换,或者至少在进行转换时对可能的后果有明确的理解。 总结 将负数转换为uint64类型可能会导致出人意料的结果。理解这一转换背后的补码机制是理解这一现象的关键。

    78620

    【模板小程序】2~62位非负数任意进制转换

    进制转换的符号表为[0-9a-zA-Z],共61个字符,最大可表示62进制。 思路是原进制先转换为10进制,再转换到目标进制。...疑问:   对于负数,有小伙伴说可以直接将符号丢弃,按照整数进行进位转换,最后再将负号补回来,我认为这种做法是不对的。   ...正确的做法是:考虑好按照16位(short)还是32位(int)抑或64位(long long),先求出二进制补码(这时候就正负数就统一了),将二进制数转换为十进制后在转换为其他进制(如果有小伙伴知道如何直接将二进制转换为任意进制的方法可以留言告诉我...下面贴上这种我认为针对负数的处理方法不太合适的代码: 输入格式:原进制,目标进制,原进制下的数字(用字符串表示) 输出格式:目标进制下的数字 1 #include 2 #include...64 strTmp='-'+strTmp; 65 cout<<strTmp<<endl; 66 } 67 68 return 0; 69 }  另外,针对非负数的进制转换部分的思想可以直接拿去用

    69120

    获取本机字节顺序(端序、尾序)

    字节顺序简单的理解就是一组数据在内存中排列的数据,分大/小端顺序,其详细的介绍可以参考维基百科,本文主要介绍的是如何通过调试查看内存中变量的储存数据以及如何通过代码实现判断本机字节顺序。...图片 通过代码判断本机字节顺序 维基百科上也介绍了哪些 CPU 是使用的是大端序、哪些是使用的小端序,而如果我们不清楚 CPU 型号时,可以通过编写一个程序来获得,第一种方式是将一个 4 字节的数值截断为...argv[]) { int i = 0x11223344; // 取 i 的地址,强制转换为 char* 类型,被解释为 1 个字节,再解引用该地址中一个字节的数据...{ cout << "Big endian" << endl; } return 0; } 另外一种方式是借助函数 htonl() 该函数把本机字节序转换为网络字节序...(大端序),我们判断如果原值等于被转换后的数据(大端序数据),那么我们的 CPU 就是大端序,反之则是小端序。

    42220

    十进制与二进制转换(负数+正数)

    一、十进制正数的二进制转换 1、9利用“除2取余法,余数逆序排列”,得到原码。 2、则9的二进制数为 0000 1001。...二、十进制负数的二进制转换 1、先将9利用“除2取余法,余数逆序排列”,得到原码。 2、将上一步骤得到的原码取反(1取0,0取1,数个数字除外,一直为1),得到反码。...3、在反码的基础上,加1得到补码。 对应的补码为:11110111。 4、十进制负数转二进制方法总结如下: 除2取余,逆序排列 。 01互换,原码取反码 。 反码+1,得补码。...三、逆向操作将二进制的负数转为十进制 1、将二进制数减1,得到:11101100。 2、将减1后的代码取反操作,得到:00010011。 3、将取反后的代码换算成十进制,得到19。...数据范围:保证在 32 位整型数字范围内 输入描述: 输入一个整数(int类型) 输出描述: 这个数转换成2进制后,输出1的个数 示例 输入:5 输出:2 输入:0 输出:0 代码: public

    52920

    什么是BOM头(字节顺序标记(ByteOrderMark))

    在utf-8编码文件中BOM在文件头部,占用三个字节,用来标示该文件属于utf-8编码,现在已经有很多软件识别bom头,但是还有些不能识别bom头,比如PHP就不能识别bom头,这也是用记事本编辑utf...类似WINDOWS自带的记事本等软件,在保存一个以UTF-8编码的文件时,会在文件开始的地方插入三个不可见的字符(0xEF 0xBB 0xBF,即BOM)。...最大的麻烦还不是这个。受COOKIE送出机制的限制,在这些文件开头已经有BOM的文件中,COOKIE无法送出(因为在COOKIE送出前PHP已经送出了文件头),所以登入和登出功能失效。...一切依赖COOKIE、SESSION实现的功能全部无效。因此,在编辑、更改任何文本文件时,请务必使用不会乱加BOM的编辑器。Linux下的编辑器应该都没有这个问题。...去掉bom头的办法,简单的是下面两种:1、editplus去BOM头的方法编辑器调整为UTF8编码格式后,保存的文件前面会多出一串隐藏的字符(也即是BOM),用于编辑器识别这个文件是否是以UTF8编码。

    4.5K10
    领券