int y = 0;
y=x>>2;
z=x<<2;
System.out.println("y="+y);
System.out.println("x="+x);
答案是y=-4,x=-56
我知道整数的位移操作是x>>i=x/2的i次方,x<<i=x*2的i次方
我不太清楚负数的位移操作,谁来解释一下
9 个解决方案
#1
System.out.println(-1>>>32);
System.out.println(1>>>32);
结果分别是什么??
我快被操作符搞晕了
System.out.println(1>>>32);
结果分别是什么??
我快被操作符搞晕了
#2
关注
#3
别只关注啊,高手们过来看看啊.
#4
移位运算符面向的运算对象也是二进制的“位”。可单独用它们处理整数类型(主类型的一种)。左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补0)。“有符号”右移位运算符(>>)则将运算符左边的运算对象向右移动运算符右侧指定的位数。“有符号”右移位运算符使用了“符号扩展”:若值为正,则在高位插入0;若值为负,则在高位插入1。Java也添加了一种“无符号”右移位运算符(>>>),它使用了“零扩展”:无论正负,都在高位插入0。这一运算符是C或C++没有的。
若对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。只有右侧的5个低位才会用到。这样可防止我们在一个int数里移动不切实际的位数。若对一个long值进行处理,最后得到的结果也是long。此时只会用到右侧的6个低位,防止移动超过long值里现成的位数。但在进行“无符号”右移位时,也可能遇到一个问题。若对byte或short值进行右移位运算,得到的可能不是正确的结果(Java 1.0和Java 1.1特别突出)。它们会自动转换成int类型,并进行右移位。但“零扩展”不会发生,所以在那些情况下会得到-1的结果。
若对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。只有右侧的5个低位才会用到。这样可防止我们在一个int数里移动不切实际的位数。若对一个long值进行处理,最后得到的结果也是long。此时只会用到右侧的6个低位,防止移动超过long值里现成的位数。但在进行“无符号”右移位时,也可能遇到一个问题。若对byte或short值进行右移位运算,得到的可能不是正确的结果(Java 1.0和Java 1.1特别突出)。它们会自动转换成int类型,并进行右移位。但“零扩展”不会发生,所以在那些情况下会得到-1的结果。
#5
Patrick_DK(疾风摩郎) 刚才是开玩笑道没别的意思!在这向你道歉!!!!:))
#6
楼上的,简短地理解为:
16位的 short , 8 位的 byte 先转成 int.
移位是针对int的,32位,超过32位的移位,按 32 取余 来移。
没有错吧?
16位的 short , 8 位的 byte 先转成 int.
移位是针对int的,32位,超过32位的移位,按 32 取余 来移。
没有错吧?
#7
超过32位的移位 等于 与32取余 的移位!!!
System.out.println(-1>>>32); === System.out.println(-1>>>0)
System.out.println(1>>>32); ===System.out.println(1>>>0)
还是 -1 和 1
System.out.println(-1>>>32); === System.out.println(-1>>>0)
System.out.println(1>>>32); ===System.out.println(1>>>0)
还是 -1 和 1
#8
OK,考SCJP的话
记住这两句话应该就行了吧?
记住这两句话应该就行了吧?
#9
题目错了
int x = 14;
int y = 0;
y=x>>2;
z=x<<2;
System.out.println("y="+y);
System.out.println("x="+x);
应该 int x = -14
int x = 14;
int y = 0;
y=x>>2;
z=x<<2;
System.out.println("y="+y);
System.out.println("x="+x);
应该 int x = -14
#1
System.out.println(-1>>>32);
System.out.println(1>>>32);
结果分别是什么??
我快被操作符搞晕了
System.out.println(1>>>32);
结果分别是什么??
我快被操作符搞晕了
#2
关注
#3
别只关注啊,高手们过来看看啊.
#4
移位运算符面向的运算对象也是二进制的“位”。可单独用它们处理整数类型(主类型的一种)。左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补0)。“有符号”右移位运算符(>>)则将运算符左边的运算对象向右移动运算符右侧指定的位数。“有符号”右移位运算符使用了“符号扩展”:若值为正,则在高位插入0;若值为负,则在高位插入1。Java也添加了一种“无符号”右移位运算符(>>>),它使用了“零扩展”:无论正负,都在高位插入0。这一运算符是C或C++没有的。
若对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。只有右侧的5个低位才会用到。这样可防止我们在一个int数里移动不切实际的位数。若对一个long值进行处理,最后得到的结果也是long。此时只会用到右侧的6个低位,防止移动超过long值里现成的位数。但在进行“无符号”右移位时,也可能遇到一个问题。若对byte或short值进行右移位运算,得到的可能不是正确的结果(Java 1.0和Java 1.1特别突出)。它们会自动转换成int类型,并进行右移位。但“零扩展”不会发生,所以在那些情况下会得到-1的结果。
若对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。只有右侧的5个低位才会用到。这样可防止我们在一个int数里移动不切实际的位数。若对一个long值进行处理,最后得到的结果也是long。此时只会用到右侧的6个低位,防止移动超过long值里现成的位数。但在进行“无符号”右移位时,也可能遇到一个问题。若对byte或short值进行右移位运算,得到的可能不是正确的结果(Java 1.0和Java 1.1特别突出)。它们会自动转换成int类型,并进行右移位。但“零扩展”不会发生,所以在那些情况下会得到-1的结果。
#5
Patrick_DK(疾风摩郎) 刚才是开玩笑道没别的意思!在这向你道歉!!!!:))
#6
楼上的,简短地理解为:
16位的 short , 8 位的 byte 先转成 int.
移位是针对int的,32位,超过32位的移位,按 32 取余 来移。
没有错吧?
16位的 short , 8 位的 byte 先转成 int.
移位是针对int的,32位,超过32位的移位,按 32 取余 来移。
没有错吧?
#7
超过32位的移位 等于 与32取余 的移位!!!
System.out.println(-1>>>32); === System.out.println(-1>>>0)
System.out.println(1>>>32); ===System.out.println(1>>>0)
还是 -1 和 1
System.out.println(-1>>>32); === System.out.println(-1>>>0)
System.out.println(1>>>32); ===System.out.println(1>>>0)
还是 -1 和 1
#8
OK,考SCJP的话
记住这两句话应该就行了吧?
记住这两句话应该就行了吧?
#9
题目错了
int x = 14;
int y = 0;
y=x>>2;
z=x<<2;
System.out.println("y="+y);
System.out.println("x="+x);
应该 int x = -14
int x = 14;
int y = 0;
y=x>>2;
z=x<<2;
System.out.println("y="+y);
System.out.println("x="+x);
应该 int x = -14