黑马程序员技术交流社区

标题: >>>与>>的一个问题 [打印本页]

作者: 张慧    时间: 2013-8-28 00:31
标题: >>>与>>的一个问题
本帖最后由 张慧 于 2013-8-29 09:13 编辑

-7>>>1的一个过程:
-7的二进制表示:1000 0000 0000 0000 0000 0000 0000 0111
-7在进行无符号右移时首先会先取补码,
反码的补码就是原码取反加一,即1111 1111 1111 1111 1111 1111 1111 1001
之后再右移一位变为:0111 1111 1111 1111 1111 1111 1111 1100

-7>>1的一个过程:
-7的二进制表示:1000 0000 0000 0000 0000 0000 0000 0111
-7在进行无符号右移时首先会先取补码,
反码的补码就是原码取反加一,即1111 1111 1111 1111 1111 1111 1111 1001
之后再右移一位变为:0111 1111 1111 1111 1111 1111 1111 1100
然后再保留符号位再去反 即1000 0000 0000 0000 0000 0000 0000 0011
再加一:1000 0000 0000 0000 0000 0000 0000 0100(-4)

不是很明白为什么要这么做?





作者: yxz    时间: 2013-8-28 08:00
计算机数据是二进制存储的,8进制 10进制 16进制,都是经过软件转换便于阅读的。
所以二进制的的性能是最高的,按位操作符是二进制算法,性能最好的。
一般hash算法会用按位操作符。
作者: 张慧    时间: 2013-8-28 12:57
yxz 发表于 2013-8-28 08:00
计算机数据是二进制存储的,8进制 10进制 16进制,都是经过软件转换便于阅读的。
所以二进制的的性能是最高 ...

谢谢你的回答。就是负数在进行位移运算的时候不同于正数,这个具体的原因以及过程中为什么要那么运算,不是很明白。

作者: yxz    时间: 2013-8-28 15:42
张慧 发表于 2013-8-28 12:57
谢谢你的回答。就是负数在进行位移运算的时候不同于正数,这个具体的原因以及过程中为什么要那么运算,不 ...

byte a=-7;这时a=11111001
11111001>>1 = 11111100
11111001>>>1 = 01111100


二进制里第最高位是符号

作者: 黑马-张辉    时间: 2013-8-29 00:02
刚开始以为是一个人自问自答,头像太有欺骗性了
作者: 潘才新    时间: 2013-8-29 01:05
张慧 发表于 2013-8-28 12:57
谢谢你的回答。就是负数在进行位移运算的时候不同于正数,这个具体的原因以及过程中为什么要那么运算,不 ...

亲!问题解决了吗?解决了,将未解决改成已解决!

作者: 张慧    时间: 2013-8-29 09:08
潘才新 发表于 2013-8-29 01:05
亲!问题解决了吗?解决了,将未解决改成已解决!

嗯,好的~




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2