
-128存放在一个字节中是以补码形式存放的
求-128的补码二进制表示:先看128的二进制表示10000000,取反=01111111,加1=10000000
所以-128的单字节表示为10000000

2022-05-15 广告
一个字节是 8 位二进制数。理应表示 2^8 = 256 的数值。
8 位数的补码,确确实实,它就可以表示 256 个数值。
其中有 128 个负数:-128 ~-1。
另外是 128 个非负数:0 ~ +127。
但是,8 位的原码和反码,却只能表示 255 个数值,缺少了一个:-128。
那么,用常说的“取反加一”方法求-128 的 8 位补码,显然是行不通的。
在字长为 8 位时,原码和反码的表示范围只是:-127 ~ +127,表示不了-128。 这也就是说:-128 没有 8 位的原码和反码。 没有原码,拿什么取反? 没有反码,拿什么加一? 因此,用“取反加一”的方法求-128 的 8 位补码,是无处下手的。
为什么会有这种现象发生?
因为,在原码和反码中,计算机专家都对一个零编了两个码(+0-0),于是,原码和反码就必然少表示一个数。 这个数就是-128。 而在补码中,并没有多余的零,所以,补码就能表示-128。
没有原码和反码,怎么求补码呢? 如果你死心眼的偏要用取反加一,你就要碰壁了。
其实,补码的来历,并非是“取反加一”。 补码是有定义式的,你回去看看计算机的教材,书上一定会发现这个公式的:[ X ]补码=2^8+X,n 是补码的位数。
那么,[-128 ]八位补码=2^8-128 = 128 = 1000 0000 (二进制补码)。
利用定义式求补码,是非常简单方便的,既不用背诵:机器数真值符号位原码反码 ... 这一滩垃圾,也不会在-128 这里处于绝境。
但是,老外的算术水平太洼,也就只好用那些繁琐的方法了。 而且,即使他们求不出来-128 的补码,也由于他们的出色表演,让你看的眼花缭乱,佩服的不得了,也就忽略了-128 应该如何表示了! 只有像题主这种清醒的人,才会注意到-128 的问题。
其实,那些花活,只不过是忽悠罢了,你如果看过《卖拐》就明白计算机老师的用意。