问题: printf(“%x,%d\n”,~7,~7);
解:
十进制数字 7 的二进制码
00000000 00000000 00000000 00000111
按位取反运算 ~7
11111111 11111111 11111111 11111000
所以 printf(“%x\n”,~7); //十六进制输出:fffffff8
11111111 11111111 11111111 11111000 的最高八位符号位(11111111,表示负数),有符号整数在计算机中采用补码存储,即 该二进制数为所求整数的补码。
负数的补码 = 原码 取反 + 1;
所以 原码 = 补码 – 1 取反
所以有:
11111111 11111111 11111111 11111000(补码)
11111111 11111111 11111111 11110111( -1 )
11111111 00000000 00000000 00001000(取反 得到原码 -8)
所以 printf(“%d\n”,~7); //十进制输出:-8
今天的文章c语言取反运算符_c语言入门基础100题分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/74806.html