黑马程序员技术交流社区

标题: 位移问题 [打印本页]

作者: 仲伟    时间: 2013-5-12 20:59
标题: 位移问题
本帖最后由 仲伟 于 2013-5-13 13:13 编辑

2 << 3

三个
2<<3与
2<<<3
要求写出 运算公式,或者计算方法
请举出详细的实例

作者: 张迁    时间: 2013-5-12 21:11
两个表示带符号移位,三个表示无符号移位
作者: 8047107    时间: 2013-5-12 21:28
两个表示带符号移位,三个表示无符号移位
正数可用>>,负数的话就需要>>>,因为最高位都是需要补0的,如果负数也是>>最高位就补的是1了,这样就错了~!~所以用>>>把!
作者: 陈志强    时间: 2013-5-12 21:30
<<与<<<
<<是左移,是一种以二进制形式的快速运算,操作的是二进制,所以位移是最快的运算,左移是32位的二进制往左边移动n位,n值的是左移的位数。比如2<<3值的是2的二进制数往左移3位,其直接操作是2乘以2(3)是2乘以2的立方。
在内存中是把32位二进制左移后,后面的空位用0补。
<<<是无符号左移,也是一种二进制运算,指的是,当我们对负数进行右移的时候,如果用>>的话,那么你右移的时候,前面的永远补上的是1,这样的话那么你就永远移不完,所以这个时候就用无符号右移,这样的话,那么在二进制数的最前面就是用0补,那么你就会将这个数的二进制位移完,就不会出现移不完的情况了,这就是它们的区别。
希望对你有点帮助。

作者: nihaoshitou    时间: 2013-5-12 21:33
1)《(左移)

运算规则:按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零。

语法格式:

需要移位的数字 《 移位的次数

例如: 5 《 2,则是将数字5左移2位

计算过程:

5 《 2

首先把3转换为二进制数字(int类型的话为32位,8字节;long的话为64位16字节)0000 0000 0000 0000 0000 0000 0000 0101,然后把该数字高位(左侧)的两个零移出,其他的数字都朝左平移2位,最后在低位(右侧)的两个空位补零。则得到的最终结果是0000 0000 0000 0000 0000 0000 0001 0100,则转换为十进制是20

数学意义:在数字没有溢出的前提下,对于正数和负数,左移一位都相当于乘以2的1次方,左移n位就相当于乘以2的n次方。比如5 《 2 = 5 * 4

2)》(带符号右移)

运算规则:按二进制形式把所有的数字向右移动对应位数,低位移出(舍弃),高位的空位补符号位,即正数补0,负数补1.

语法格式:

需要移位的数字 》 移位的次数

例如11 》 2,则是将数字11右移2位

计算过程:11的二进制形式为:0000 0000 0000 0000 0000 0000 0000 1011,然后把低位的最后两个数字移出,因为该数字是正数,所以在高位补零。则得到的最终结果是0000 0000 0000 0000 0000 0000 0000 0010.转换为十进制是3.

数学意义:右移一位相当于除2,右移n位相当于除以2的n次方。

3)>>>(无符号右移)。

运算规则:按二进制形式把所有的数字向右移动对应位数,低位移出(舍弃),高位的空位补零。其他结构和》相似。

位移运算通常用来对代码进行速度上的优化,用它来代替乘除法将是很好的选择。
作者: 曹睿翔    时间: 2013-5-12 21:46
楼主注意提问的技巧,适当提高难度
作者: 仲伟    时间: 2013-5-12 21:48
曹睿翔 发表于 2013-5-12 21:46
楼主注意提问的技巧,适当提高难度

我提问太多了,有点不好意思了啊。今天这个最后一个次
作者: 曹睿翔    时间: 2013-5-12 21:52
仲伟 发表于 2013-5-12 21:48
我提问太多了,有点不好意思了啊。今天这个最后一个次

技术分不是问题,去把你刚才在我发的帖子回的从新编辑下,领两个,技术分就够25了
作者: 仲伟    时间: 2013-5-12 21:56
曹睿翔 发表于 2013-5-12 21:52
技术分不是问题,去把你刚才在我发的帖子回的从新编辑下,领两个,技术分就够25了 ...

刚刚那个帖子啊,怎么编辑,就是回答你上面的问题吗??,还是找问题,提问啊




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