免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5733 | 回复: 10
打印 上一主题 下一主题

[技术动态] 原、反、补 你真的弄懂了吗? [复制链接]

论坛徽章:
1
巨蟹座
日期:2014-03-18 23:44:30
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-09-20 23:54 |只看该作者 |倒序浏览
下面例子设定为 8 位处理
正数的原反补相同
负数 的补码 = 非符号位变反加一

你能给出 -128 的原码吗?????

论坛徽章:
0
2 [报告]
发表于 2012-09-21 00:26 |只看该作者
8位原码和反码表示范围都是-127 ~ 127,因为0有两种不同表示。只有8位补码才能表示-128 ~ 127

论坛徽章:
0
3 [报告]
发表于 2012-09-21 02:08 |只看该作者
本帖最后由 ethantsien 于 2012-09-21 03:04 编辑

为什么大家描述补码都要通过反码来描述呢,为什么不用数学公式直接来描述补码呢?

负数有三种表示方式:补码,反码或者原码,基本上所有的机器都是用补码来表示负数。

假设负数的位向量是[xn-1xn-2...x0]
负数的补码= -xn-1 * 2的n-1次方+xn-2 * 2的n-2次方+...+x0 * 2的0次方

不好打数学公式,所以只能这么描述

由于-128=-(2的7次方),所以-128的补码表示方式是10000000

由于原码最高有效位是符号位,只用来确定值是负的还是正的,所以
原码的表示方式是:(-1)的xn-1次方 * ( xn-2 * 2的n-2次方+xn-2 * 2的n-2次方+...+x0 * 2的0次方 )

所以-128的原码表示方式是不存在的



论坛徽章:
89
水瓶座
日期:2014-04-01 08:53:31天蝎座
日期:2014-04-01 08:53:53天秤座
日期:2014-04-01 08:54:02射手座
日期:2014-04-01 08:54:15子鼠
日期:2014-04-01 08:55:35辰龙
日期:2014-04-01 08:56:36未羊
日期:2014-04-01 08:56:27戌狗
日期:2014-04-01 08:56:13亥猪
日期:2014-04-01 08:56:02亥猪
日期:2014-04-08 08:38:58程序设计版块每日发帖之星
日期:2016-01-05 06:20:00程序设计版块每日发帖之星
日期:2016-01-07 06:20:00
4 [报告]
发表于 2012-09-21 08:38 |只看该作者
我觉得这个挺恶心的。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
5 [报告]
发表于 2012-09-21 10:51 |只看该作者
1字节内的-128实际上是符号位和数值位重叠了, 没有什么讨论的价值, 楼主看看下面的代码有没有问题(理解溢出这一个概念就足够了)?
  1. [liangdong@bb-browser-test00.vm.baidu.com c_project]$ make
  2. gcc -g -I.   -c -o main.o main.c
  3. main.c: In function `main':
  4. main.c:8: warning: comparison is always true due to limited range of data type
  5. gcc -o main main.o -lpthread -lm
  6. [liangdong@bb-browser-test00.vm.baidu.com c_project]$ ./main

  7. [liangdong@bb-browser-test00.vm.baidu.com c_project]$ cat main.c
  8. #include <stdio.h>
  9. #include <stdlib.h>
  10. #include <string.h>

  11. int main(int argc, char* const argv[]) {
  12.         char i;

  13.         for (i = 0; i < 128; ++ i) {
  14.         }

  15.         return 0;
  16. }
复制代码

论坛徽章:
1
巨蟹座
日期:2014-03-18 23:44:30
6 [报告]
发表于 2012-09-27 14:37 |只看该作者
回复 2# sonicling


    0 的两种不同表现形式, for example 一个:
    +0: 0x00
    -0:  ??

论坛徽章:
1
巨蟹座
日期:2014-03-18 23:44:30
7 [报告]
发表于 2012-09-27 14:46 |只看该作者
回复 5# linux_c_py_php


    计算机内部如何处理这种重叠呢,如何区分呢??

论坛徽章:
0
8 [报告]
发表于 2012-09-27 15:30 |只看该作者
socay2 发表于 2012-09-27 14:37
回复 2# sonicling


    0 的两种不同表现形式, for example 一个:
    +0: 0x00
    -0:  ??


   原码 反码 补码
+0 :0x00 0x00 0x00
-0 :0x80 0xff 0x00

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
9 [报告]
发表于 2012-09-27 16:01 |只看该作者
回复 7# socay2

  1.      1000 0000          =补
  2. +   1000 0000          =128
  3. _____________
  4. =1 0000 0000        ~=0000 0000
复制代码

论坛徽章:
1
巨蟹座
日期:2014-03-18 23:44:30
10 [报告]
发表于 2012-09-27 23:09 |只看该作者
回复 8# sonicling
谢谢!!

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP