搜索
bottom↓
回复: 5

请教一个32位整型取反的问题

[复制链接]

出0入0汤圆

发表于 2013-4-19 15:53:17 | 显示全部楼层 |阅读模式
    调试板子时出现一个错误,然后查看了一下汇编代码后发现:

   ~0X00008000的结果是0X00007FFF;

而 ~0X00007000的结果就是0XFFFF8FFF

经过几次不同数据的试验,好像第15位为1,则高16位就不取反,而第15位为0,则高16位也会取反,

这是什么情况呢?
  1.         e = ~0x00007000;
  2. 1c0:        8f ef               ldi        r24, 0xFF        ; 255
  3. 1c2:        9f e8               ldi        r25, 0x8F        ; 143
  4. 1c4:        af ef               ldi        r26, 0xFF        ; 255
  5. 1c6:        bf ef               ldi        r27, 0xFF        ; 255
  6. 1c8:        8d 83               std        Y+5, r24        ; 0x05
  7. 1ca:        9e 83               std        Y+6, r25        ; 0x06
  8. 1cc:        af 83               std        Y+7, r26        ; 0x07
  9. 1ce:        b8 87               std        Y+8, r27        ; 0x08
  10.         e = ~0x00008000;
  11. 1d0:        8f ef               ldi        r24, 0xFF        ; 255
  12. 1d2:        9f e7               ldi        r25, 0x7F        ; 127
  13. 1d4:        a0 e0               ldi        r26, 0x00        ; 0
  14. 1d6:        b0 e0               ldi        r27, 0x00        ; 0
  15. 1d8:        8d 83               std        Y+5, r24        ; 0x05
  16. 1da:        9e 83               std        Y+6, r25        ; 0x06
  17. 1dc:        af 83               std        Y+7, r26        ; 0x07
  18. 1de:        b8 87               std        Y+8, r27        ; 0x08
  19.         e = ~0x00008001;
  20. 1e0:        8e ef               ldi        r24, 0xFE        ; 254
  21. 1e2:        9f e7               ldi        r25, 0x7F        ; 127
  22. 1e4:        a0 e0               ldi        r26, 0x00        ; 0
  23. 1e6:        b0 e0               ldi        r27, 0x00        ; 0
  24. 1e8:        8d 83               std        Y+5, r24        ; 0x05
  25. 1ea:        9e 83               std        Y+6, r25        ; 0x06
  26. 1ec:        af 83               std        Y+7, r26        ; 0x07
  27. 1ee:        b8 87               std        Y+8, r27        ; 0x08
复制代码

阿莫论坛20周年了!感谢大家的支持与爱护!!

你熬了10碗粥,别人一桶水倒进去,淘走90碗,剩下10碗给你,你看似没亏,其实你那10碗已经没有之前的裹腹了,人家的一桶水换90碗,继续卖。说白了,通货膨胀就是,你的钱是挣来的,他的钱是印来的,掺和在一起,你的钱就贬值了。

出0入0汤圆

发表于 2013-4-19 16:00:41 | 显示全部楼层
默认整数常量是int16,试试:
~0X00008000L
~0X00007000L

出0入0汤圆

 楼主| 发表于 2013-4-19 16:05:41 | 显示全部楼层
本帖最后由 jiege0119 于 2013-4-19 16:10 编辑
shark 发表于 2013-4-19 16:00
默认整数常量是int16,试试:
~0X00008000L
~0X00007000L


嗯,这样是可以的,我不明白的是为什么~0X00007000就当32位取反,而~0X00008000就只有16位取反了

出0入0汤圆

发表于 2013-4-19 16:07:38 | 显示全部楼层
jiege0119 发表于 2013-4-19 16:05
嗯,这样是可以的,我不明白的是为什么~0X00007000L就当32位取反,而~0X00008000就只有16位取反了 ...

没有尾巴的常数是int类型。

出0入0汤圆

 楼主| 发表于 2013-4-19 16:15:00 | 显示全部楼层
dr2001 发表于 2013-4-19 16:07
没有尾巴的常数是int类型。

如果这个数小于0X00008000,那么没有尾巴也是按32位的来处理

出0入0汤圆

发表于 2013-4-19 16:18:19 | 显示全部楼层
jiege0119 发表于 2013-4-19 16:05
嗯,这样是可以的,我不明白的是为什么~0X00007000就当32位取反,而~0X00008000就只有16位取反了 ...

我猜可能是这样的:
~0X00008000  ==>  ~0x8000  ,这是个负数,所以取反之前自动扩展了符号位到高16位==>  ~(0xFFFF8000) ==> 0x00007FFF

~0X00007000 ==>  ~0x7000 , 这个是正数, ===========================> ~(0x00007000) ==> 0xFFFF8FFF

回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-10-3 16:45

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表