首页 > 编程语言 > 详细

C语言取反运算~

时间:2014-09-09 13:50:59      阅读:170      评论:0      收藏:0      [点我收藏+]

问题:  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语言取反运算~

原文:http://taiyi928.blog.51cto.com/7898859/1549877

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!