免费注册 查看新帖 |

Chinaunix

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

[C] 请教一个位运算的简单问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-05-07 21:48 |只看该作者 |倒序浏览
代码很短:

#include <stdio.h>
#include <stdlib.h>

int main()
{
        unsigned char a = 0xff;
        unsigned char b = ~a>>4;
        printf("b == %x\n", b);
        exit(0);
}

~的优先级是要大于>>的,但是为什么得到的输出是f0而不是0?
我在~a上加上括号变成
        unsigned char b = (~a)>>4;
还是得到同样的结果f0。
而如果:
        unsigned char b = ~a;
        b >>= 4;
就输出0了。
有什么我疏忽的地方么?
我用的是gcc 4.3.2编译器。

谢谢!

论坛徽章:
0
2 [报告]
发表于 2009-05-07 22:14 |只看该作者
隐约记得char在表达式中提升为int, 所以就是0xff -> 0x000000ff  
~a -> 0xffffff00

论坛徽章:
0
3 [报告]
发表于 2009-05-07 22:18 |只看该作者
原帖由 bsdc 于 2009-5-7 22:14 发表
隐约记得char在表达式中提升为int, 所以就是0xff -> 0x000000ff  
~a -> 0xffffff00

有道理啊!
待我再去查查书~
thx!

论坛徽章:
0
4 [报告]
发表于 2009-05-07 22:21 |只看该作者
虽然是win下的,但是弄成汇编也能说明问题,原理是一样的:
        unsigned char a = 0xff;
0040101C  mov         byte ptr [a],0FFh
        unsigned char b = ~a>>4;
00401020  movzx       eax,byte ptr [a]
00401024  not         eax  
00401026  sar         eax,4
00401029  mov         byte ptr ,al

很明显b=~a>>4;因为优先级的问题,~是先操作的,但是首先是把a放入ax,然后在ax上操作,最后将al放入b中

现在的ax是16位或者32位的(32位机的eax),而a只有8位,那么a存入ax的时候高位是存在的是0,因此执行~操作的时候高位就变成1了。

同时右移四位就将高位的1移入四个,加上原先的四个0,就是0xf0了

论坛徽章:
0
5 [报告]
发表于 2009-05-07 22:30 |只看该作者
嗯。
其实就是promotion的原因。
两个char进行计算,在int能够符合的情况下总会先promote至int进行计算的。所以高位就在这个过程中被填充。之后的取反也就有了f。
谢谢!

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
6 [报告]
发表于 2009-05-07 22:47 |只看该作者
应该是循环移位的问题
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP