当前位置: 技术问答>java相关
一個又簡單又複雜的又很煩的問題,我願意奉上50分。
来源: 互联网 发布时间:2015-05-02
本文导语: thinking in java 中說到無符右移中有一段程序 : int i = -1; i >>>=10; long l = -1; l >>>= 10; short s = -1; s >>>= 10; byt...
thinking in java 中說到無符右移中有一段程序 :
int i = -1;
i >>>=10;
long l = -1;
l >>>= 10;
short s = -1;
s >>>= 10;
byte b = -1;
b >>>= 10;
結果為:
i = 4194303 ---只說它就行了,最好能全說了。
l = 18014398509481983
s = -1
b = -1
哪位老兄解釋一下;
int i = -1;
i >>>=10;
long l = -1;
l >>>= 10;
short s = -1;
s >>>= 10;
byte b = -1;
b >>>= 10;
結果為:
i = 4194303 ---只說它就行了,最好能全說了。
l = 18014398509481983
s = -1
b = -1
哪位老兄解釋一下;
|
赋值 二进制
int i = -1 11111111111111111111111111111111(32位)
i >>>= 10 00000000001111111111111111111111(22个1)
long(64位)同理
若对byte或short值进行右移位运算,得到的可能不是正确的结果(Java 1.0和Java 1.1特别突出)。它们会自动转换成int类型,并进行右移位。但“零扩展”不会发生,所以在那些情况下会得到-1的结果。(Thinking in java 原语)
int i = -1 11111111111111111111111111111111(32位)
i >>>= 10 00000000001111111111111111111111(22个1)
long(64位)同理
若对byte或short值进行右移位运算,得到的可能不是正确的结果(Java 1.0和Java 1.1特别突出)。它们会自动转换成int类型,并进行右移位。但“零扩展”不会发生,所以在那些情况下会得到-1的结果。(Thinking in java 原语)
|
+1的原码:0000000000000000000000000000001
求反码:11111111111111111111111111111110
-1为(+1补码):11111111111111111111111111111110在最低位加1:11111111111111111111111111111111
求反码:11111111111111111111111111111110
-1为(+1补码):11111111111111111111111111111110在最低位加1:11111111111111111111111111111111
|
这是补码表示
|
“无符号”右移位运算符(>>>)是Java独有的,它使用了“零扩展”:无论正负,都在高位插入0。
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。