Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1560198
  • 博文数量: 3500
  • 博客积分: 6000
  • 博客等级: 准将
  • 技术积分: 43870
  • 用 户 组: 普通用户
  • 注册时间: 2008-05-03 20:31
文章分类

全部博文(3500)

文章存档

2008年(3500)

我的朋友

分类:

2008-05-04 23:43:14

一起学习
Java中的移位,如果是short,char,byte的话,都会转换成int的形式再进行移位的。

试看:

1.) byte a = 27;// 转换成int为 00000000000000000000000000011011

byte b = -1;转换成int为 11111111111111111111111111111111

int g = a >> 1;// 有符号右移1位,左侧缺的位以符号位补齐,正数就是0, "00000000000000000000000000001101" = 13

int f = b>> 1; // 有符号右移1位,左侧缺的位以符号位补齐,负数就是1, “11111111111111111111111111111111”= -1

故此时打印出来,g=13,gf=-1。

g = a >>> 1;// 无符号右移1位,左侧缺的位以0补齐, "00000000000000000000000000001101" = 13

f = b>>> 1; // 无符号右移1位,左侧缺的位以0补齐, “01111111111111111111111111111111”= 2147483647

故此时打印出来,g=13,gf=2147483647。

f = b<< 1; // 无符号左移1位,右侧缺的位以0补齐, “10000000000000000000000000000010“= -2

故此时打印出来,f= -2

在Thinking in Java第三章中的一段话:

移位运算符面向的运算对象也是二进制的“位”。 可单独用它们处理整数类型(主类型的一种)。左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补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的结果

TAG: java基础

下载本文示例代码


Java中移位操作符的运算规则Java中移位操作符的运算规则Java中移位操作符的运算规则Java中移位操作符的运算规则Java中移位操作符的运算规则Java中移位操作符的运算规则Java中移位操作符的运算规则Java中移位操作符的运算规则Java中移位操作符的运算规则Java中移位操作符的运算规则Java中移位操作符的运算规则Java中移位操作符的运算规则
阅读(652) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~