对于整行是如何在计算机中存储的 ,有如下理解。
无符号数是没有原码,反码和补码的概念的。这些概念只是针对有符号数。
对于有符号数来说。正数的原码,反码和补码是相同的。对于负数,有这样的转化关系。
原码-》反码:除最高为符号位外,其余的位置按位取反。
反码-》补码:在反码的基础上在最后一位加1,符号位保持不变。
例如:有符号位的正数,表示范围是从0000 0000到0111 1111,所以正数的表示范围是0-127.在计算机中,有符号位的正数,可以理解为就是按照原码的形式存放的。
对于有符号位的负数,它们在计算机中是以补码的形式存放的。是从1000 0001到1111 1111表示-127到0.因为补码还有一个1000 0000,这个值表示-128.这是经过如下换算得来的。
(-1) + (-127) = [1000 0001]原 + [1111 1111]原 = [1111 1111]补 + [1000 0001]补 = [1000 0000]补
以下是计算机中使用补码进行运算的解释。
首先, 因为人脑可以知道第一位是符号位, 在计算的时候我们会根据符号位, 选择对真值区域的加减. (真值的概念在本文最开头). 但是对于计算机, 加减乘数已经是最基础的运算, 要设计的尽量简单. 计算机辨别"符号位"显然会让计算机的基础电路设计变得十分复杂! 于是人们想出了将符号位也参与运算的方法. 我们知道, 根据运算法则减去一个正数等于加上一个负数, 即: 1-1 = 1 + (-1) = 0 , 所以机器可以只有加法而没有减法, 这样计算机运算的设计就更简单了.
于是人们开始探索 将符号位参与运算, 并且只保留加法的方法. 首先来看原码:
计算十进制的表达式: 1-1=0
1 - 1 = 1 + (-1) = [00000001]原 + [10000001]原 = [10000010]原 = -2
如果用原码表示, 让符号位也参与计算, 显然对于减法来说, 结果是不正确的.这也就是为何计算机内部不使用原码表示一个数.
为了解决原码做减法的问题, 出现了反码:
计算十进制的表达式: 1-1=0
1 - 1 = 1 + (-1) = [0000 0001]原 + [1000 0001]原= [0000 0001]反 + [1111 1110]反 = [1111 1111]反 = [1000 0000]原 = -0
发现用反码计算减法, 结果的真值部分是正确的. 而唯一的问题其实就出现在"0"这个特殊的数值上. 虽然人们理解上+0和-0是一样的, 但是0带符号是没有任何意义的. 而且会有[0000 0000]原和[1000 0000]原两个编码表示0.
于是补码的出现, 解决了0的符号以及两个编码的问题:
1-1 = 1 + (-1) = [0000 0001]原 + [1000 0001]原 = [0000 0001]补 + [1111 1111]补 = [0000 0000]补=[0000 0000]原
这样0用[0000 0000]表示, 而以前出现问题的-0则不存在了.而且可以用[1000 0000]表示-128:
(-1) + (-127) = [1000 0001]原 + [1111 1111]原 = [1111 1111]补 + [1000 0001]补 = [1000 0000]补
-1-127的结果应该是-128, 在用补码运算的结果中, [1000 0000]补 就是-128. 但是注意因为实际上是使用以前的-0的补码来表示-128, 所以-128并没有原码和反码表示.(对-128的补码表示[1000 0000]补算出来的原码是[0000 0000]原, 这是不正确的)
使用补码, 不仅仅修复了0的符号以及存在两个编码的问题, 而且还能够多表示一个最低数. 这就是为什么8位二进制, 使用原码或反码表示的范围为[-127, +127], 而使用补码表示的范围为[-128, 127].
因为机器使用补码, 所以对于编程中常用到的32位int类型, 可以表示范围是: [-231, 231-1] 因为第一位表示的是符号位.而使用补码表示时又可以多保存一个最小值
参考
http://www.cnblogs.com/zhangziqiu/archive/2011/03/30/ComputerCode.html
分享到:
相关推荐
c++ 计算机底层 原码反码补码的练习题,包括答案
程序可将不限定位数的原码转成补码和反码,将反码转换成原码和补码,将补码转换成原码和反码,程序基于.NET 4.0,使用VS2012开发工具编写。
原码反码补码讲课.pptx
数字的原码、反码和补码
原码反码和补码PPT学习教案.pptx
16进制(4位)到二进制原码、反码、补码计算
/* *功能实现任意二进制数的原码 反码 补码转换 *仅仅是字符串的操作,没有进行数字操作 *对-0的操作可能有问题 *ssfshine@gmail.com */
本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法.
原码、反码、补码
计算机中的原码、反码和补码的详细解释。。。。
原码反码补码PPT学习教案.pptx
原码反码补码图解.原码反码补码图解.原码反码补码图解.
学习原码, 反码和补码之前, 需要先了解机器数和真值的概念
利用C++的MFC实现原码、补码、反码的转换
原码、反码、补码、移码与浮点.doc
讲说原码 补码以及反码的基本知识,需要时可以看一看。
原码、反码、补码 的相关原理 原码、反码、补码 的相关原理
对于原码,反码和补码很懵逼的人群
原码 (1) 原码:在数值前直接加一符号位的表示法。 例如: 符号位 数值位 byte的取值范围 [+7]原= 0 0000111 B [-7]原= 1 0000111 B 注意: byte的取值范围是-2^7~ 2^7-1 总计256个数 即: 无符号位 0~255 (因为...
本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希望本文对大家...