在Java中取代了很长一段时间

时间:2014-03-11 15:26:32

标签: java bit-shift

我确信无论谁先看到它,这都很容易!

为什么Java中的代码类似

   long one = 1 << 0;
   long thirty = 1 << 30;
   long thirtyOne = 1 << 31;
   long thirtyTwo = 1 << 32;

   System.out.println(one+" = "+Long.toBinaryString(1 << 0));
   System.out.println(thirty+" = "+Long.toBinaryString(1 << 30));
   System.out.println(thirtyOne+" = "+Long.toBinaryString(1 << 31));
   System.out.println(thirtyTwo+" = "+Long.toBinaryString(1 << 32));

打印

1 = 1
1073741824 = 1000000000000000000000000000000
-2147483648 = 1111111111111111111111111111111110000000000000000000000000000000
1 = 1

这对我没有意义。 long是一个64位数字 - 而它似乎在上面就像int。我知道bithifted byte进行了促销活动,但我不知道在这种情况下会发生什么。

关于这里发生的任何指示都会很好:)

THX

编辑:感谢所有答案 - 我在点击“提交”时意识到发生了什么,但是我进入了readonly模式,我无法删除!非常感谢!

7 个答案:

答案 0 :(得分:18)

这是因为1是int字面值,因此<<应用于整数。结果被转换为long,但到那时为时已晚。

如果你写1L&lt;&lt; 32,等。,那么一切都会好的。 L用于表示long字面值。

答案 1 :(得分:4)

首先:

Java语言规范paragraph 15.19

  

班次运营商

     

如果左侧操作数的提升类型为int,则仅使用右侧操作数的五个最低位作为移位距离。就好像右手操作数受到按位逻辑AND运算符&amp; (§15.22.1),掩码值为0x1f(0b11111)。因此,实际使用的移动距离始终在0到31的范围内,包括0和31。

     

如果左侧操作数的提升类型为long,则仅使用右侧操作数的六个最低位作为移位距离。就好像右手操作数受到按位逻辑AND运算符&amp; (§15.22.1),掩码值为0x3f(0b111111)。因此,实际使用的移位距离始终在0到63之间,包括0和63.

那么,为什么它会像你正在转移int而不是long那样工作?因为你正在转移int!请尝试使用long字面值:

long thirtyTwo = 1L << 32;

答案 2 :(得分:2)

它就像一个int,因为你正在改变它!要移动很长时间,您必须使用l后缀所有数字。

long one = 1l << 0;
long thirty = 1l << 30;
long thirtyOne = 1l << 31;
long thirtyTwo = 1l << 32;

System.out.println(one+" = "+Long.toBinaryString(1l << 0));
System.out.println(thirty+" = "+Long.toBinaryString(1l << 30));
System.out.println(thirtyOne+" = "+Long.toBinaryString(1l << 31));
System.out.println(thirtyTwo+" = "+Long.toBinaryString(1l << 32));

这给出了以下结果:

1 = 1
1073741824 = 1000000000000000000000000000000
2147483648 = 10000000000000000000000000000000
4294967296 = 100000000000000000000000000000000

答案 3 :(得分:1)

你是否正在使用int文字,其行为类似于int。请改用长文字(即1L):

System.out.println(1 << 31);
System.out.println(1L << 31);  // <--
-2147483648
2147483648

如果您有1 << 31之类的表达式,则无论分配给它的是什么,它都会评估为固定值,无论是int还是long

答案 4 :(得分:1)

这是因为默认情况下,行1中的数字long thirtyTwo = 1 << 32;int。在进行换档操作之前,您需要明确标记它。现在发生的事情是你在int上进行了转换,然后在转换完成后从int转换为long

   long one = 1l << 0;
   long thirty = 1l << 30;
   long thirtyOne = 1l << 31;
   long thirtyTwo = 1l << 32;

答案 5 :(得分:1)

问题是1是一个整数。在班次之后,它将被转换为长。尝试

   long one = 1l << 0;
   long thirty = 1l << 30;
   long thirtyOne = 1l << 31;
   long thirtyTwo = 1l << 32;

答案 6 :(得分:1)

literal 1是一个int。使用1L(L为长)并重试。