JAVA开发之 20-原码反码补码

本文介绍了计算机中表示正负数的机器数概念,包括原码、反码和补码的定义。原码直接表示数值,其中最高位为符号位。反码表示方法是正数不变,负数除符号位外各位取反。补码是正数与原码相同,负数先取反加1,用于实际存储和运算。在8位二进制下,补码的范围是[-127, 127]。" 116095702,10127195,FPGA中的NIOS II系统设计与流水灯应用,"['FPGA开发', '嵌入式系统', 'NIOS II', '硬件描述语言', 'Qsys设计']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

机器数

一个数在计算机中的二进制表示形式,叫做这个数的机器数,机器数是带符号的,在计算机中用一个数的最高位存放符号,正数为0,负数为1,比如,十进制中的+3,假设计算机字长为8位,转换成二进制就是0000 0011,如果是-3,就是1000 0011.那么,这里0000 0011和1000 0011就是机器数,

真值

因为第一位为符号位,所以机器数的形式值就不等于真正的数值,例如上面的有符号数1000 0011,其最高位1代表负,其真正数值是-3,而不是形式值131(1000 0011转换成10进制等于131),所以为了区别起见,将带符号的机器数对应的真正数值称为机器数的真值。例如:0000 0001的真值=+000 0001=+1,1000 0001的真值=-000 0001=-1

原码:

原码就是符号位加上真值的绝对值,即用第一位表示符号,其余位表示值,比如如果是8位二进制,[+1]原=0000 0001.[-1]原=1000 0001.因为第一位是符号位,所以8位二进制的取值范围就是:[1111 1111,0111 1111]即[-127,127],原码是人脑最容易理解和计算的表示方式。

反码:

反码的表示方法是:正数的反码是其本身,负数的反码是在其原码的基础上,符号位不变,其余各个位取反,[+1]=[0000 0001]原= [0000 0001]反,[-1]=[1000 0001]原=[1111 1110]反。可见如果一个反码表示的是负数,人脑无法直观的看出来它的数值,通常要将其转换成原码再计算。

补码:

补码的表示方法是:正整数的二进制补码与其二进制原码相同,负整数的二进制补码,先求与该负数相对应的正整数的二进制代码,然后所有位取反加1,不够位数时左边补1,例如,[+1]=[0000 0001]原=[0000 0001]反=[0000 0001]补,[-1]=[1000 0001]原=[1111 1110]反=[1111 1111]补,对于负数,补码表示方式也是人脑无法直观看出其数值的,通常也需要转换成原码再计算其数值。
这里写图片描述

这里写图片描述

我这个博客就是记录我的学习笔记,学习过程中看到一些好的博客内容也会转载过来,若有侵权,纯属无意,您可以与我联系,我会及时进行删除。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值