分享

按位取反运计算方法

 清风不相忘 2017-02-26
“~”运算符在c、c++、java、c#中都有,之前一直没有遇到这个运算符,今天碰到一道笔试题,经过学习,终于搞懂了。

要弄懂这个运算符的计算方法,首先必须明白二进制数在内存中的存放形式,二进制数在内存中是以补码的形式存放的

另外正数和负数的补码不一样,正数的补码,反码都是其本身,既:

正数9(1001)在内存中存储为01001,必须补上符号位

补码为01001

反码为01001,其中前面加的0是符号位,负数的是1

负数 -1(10001,开头的1为符号位)在内存中存放为,11111

其中11111为其补码

反码为11110


负数的补码是:符号位不变,其余各位求反,末位加1 ,既11111

反码是:符号位为1,其余各位求反,但末位不加1 ,既11110

也就是说,反码末位加上1就是补码

成都达内科技IT培训中心,专注Java培训,C++培训,3G培训,android培训,嵌入式培训等高端IT培训,顶级师资授课,真实项目实战,零首付,低押金,名企高薪就业。www.cdtarena.com



------------------------------------------------------------------------------------------------------------------------------------

弄懂了上述情况后,如何计算就好办了

假设有一个数~9,计算步骤如下,9=1001

其...
“~”运算符在c、c++、java、c#中都有,之前一直没有遇到这个运算符,今天碰到一道笔试题,经过学习,终于搞懂了。

要弄懂这个运算符的计算方法,首先必须明白二进制数在内存中的存放形式,二进制数在内存中是以补码的形式存放的

另外正数和负数的补码不一样,正数的补码,反码都是其本身,既:

正数9(1001)在内存中存储为01001,必须补上符号位

补码为01001

反码为01001,其中前面加的0是符号位,负数的是1

负数 -1(10001,开头的1为符号位)在内存中存放为,11111

其中11111为其补码

反码为11110


负数的补码是:符号位不变,其余各位求反,末位加1 ,既11111

反码是:符号位为1,其余各位求反,但末位不加1 ,既11110

也就是说,反码末位加上1就是补码

成都达内科技IT培训中心,专注Java培训,C++培训,3G培训,android培训,嵌入式培训等高端IT培训,顶级师资授课,真实项目实战,零首付,低押金,名企高薪就业。www.cdtarena.com



------------------------------------------------------------------------------------------------------------------------------------

弄懂了上述情况后,如何计算就好办了

假设有一个数~9,计算步骤如下,9=1001

其补码为01001,

对其取反10110,这个数是在内存中存放的,现在需要装换成原码,既先减1,然后取反得

11010,符号位为1是负数,既-10
0
显示全文

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多