以下代码: unsigned char a=0xa5; unsigned char b=~a >>1+2+3; 求b等于多少? 请写出具体过程

如题所述

调试了好久终于知道为什么了.

我们先看看编译器是如何编译的

not是按位取反

sar是右移 0x6也就是右移六位

但是我怎么算都是不会是fd, 这就很气╭(╯^╰)╮

然后我把代码改了下

#include "stdio.h"

int main(int argc, char const *argv[]) {
    unsigned char a = 0xa5;
    printf ( "%0x", ~a );   //显示ffffff5a
    unsigned char b = (~a) >> ( 1 + 2 + 3);

    printf ( "\n%0x  %0x", b, 0xffffff5a >> 6  ); //显示fd  3fffffd
    return 0;
}

这下就很明了了.

一开始编译器把无符号char类型的a升为32位的类型(比如int?) 进行了按位取反得到的结果ffffff5a, 然后右移六位再降为八位的无符号char类型, 也就是最后八位0xfd赋值给b

呼, 给个采纳好么QwQ

温馨提示:答案为网友推荐,仅供参考
第1个回答  2017-04-30
b==0xfd。
第2个回答  2018-04-22
真不知道为什么要这样设计,而且还出这样的题目很明显如果从C语言的角度应该汇编代码不应该放在eax里面的,应该要放在al里面的,这样才符合逻辑,不然就是设计上面的bug,看了汇编语言感觉太坑了
相似回答