public class Shift{
public static void shift1(){
int i = 0;
while(-1 << i != 0){
i++
}
}
public void shift2(){
for(int i=-1;i!=0;i<<=1){
System.out.println(i);
}
}
}
第一个方法进入无限循环,第二个方法迭代31次变成0;为什么java在移位时只考虑右操作数的低位5位?
最佳答案
因为这就是 Java Language Specification 中指定的内容: “如果左侧操作数的提升类型为 int,则仅使用右侧操作数的最低 5 位作为移位距离。”
很多硬件也是这样工作的。
关于java - 关于轮类运算符(operator),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18094746/