我确信无论谁先看到它,这都很容易!
为什么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
模式,我无法删除!非常感谢!
答案 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为长)并重试。