(零)进制及数值数据的编码 1.0.0

本文介绍了计算机中数值数据的编码方式,包括原码、反码和补码的概念。原码直接用最高位表示符号,但加减运算存在错误;反码对负数取反,但仍存在问题;补码通过在反码基础上加1解决了这个问题,成为计算机中数据的一般表示方式,简化了运算规则。
摘要由CSDN通过智能技术生成

一、计算机中数值数据的编码和表示

机器数真值 – 实际运算中,数是有正负的,计算机中数也有正负,通过用一个数的最高位 表示符号,如果字长为8位,分别为D7~~D0,那么D7为符号位,0表示正 数,1表示负数,D6~D0为数值位

– 例如:
▪ 11010111 = -87

▪ 这样,在计算机中,连同符号一起数码化的数,就被称为机器数, 如上面的11010111;而使用正负号加其绝对值的表示方法,称 为该数的真值,如-87

二、原码

▪ 原码是指将最高位作为符号位(0表示正,1表示负),其它数字 位代表数值本身的绝对值的数字表示方式 – 数字6在计算机中原码表示为:0000 0110 – 数字-6在计算机中原码表示为:1000 0110

▪ 以上是在8位计算机中的原码表示,如果在32位或16位计算机中, 表示方法是一样的,只是多了几个0而已

▪ 有了数值的表示方法就可以对数进行算数运算,但是很快就发现 用带符号位的原码进行乘除运算时结果正确,而在加减运算的时 候回出现问题,如下:

▪ (1)10 - (1)10 = (1)10+(-1)10 = (0)10
▪ (00000001)原+(10000001)原=(10000010)原=(-2)
▪ 显然是不正确的

三、反码

▪ 反码表示规则为

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值