- 浏览: 189022 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
netwelfare:
这篇文章关于jsessionid讲解的不错。关于jsessio ...
关于JSessionID【转】 -
ITcms:
Activity直接执行了onCreate方法的那部分,我觉得 ...
Android之Activity学习 -
tinygroup:
Sorry发错了。
蛇形矩阵的java实现 -
tinygroup:
public static int[][] spira ...
蛇形矩阵的java实现 -
laitao:
[*]引用pulic djs
Servlet的生命周期
在Think in Java中有这么一段话“对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。只有右侧的5个低位才会有用。这样可防止我们在一个int数里移动不切实际的位数。若对一个long值进行处理,最后得到的结果也是long。此时只会用到右侧的6个低位,防止移动超过long值里现成的位数。” 对上面那段话的理解是:移位操作符操作的运算对象是二进制的“位”,int类型是32位也就是2的5次幂 !如果移32位以上,那么原来的数的信息会全部丢失,这样也就没有什么意义了!所以上面的“只有右侧的5个低位才会有用”说的是:移位操作符右端的那个数(化成二进制)的低5位才有用,即 X < <y; 是指y的低5位才有用,即不能大于32。 而对于long型也是同样的道理! 因此,如果对一个int 型,进行移位,X < <y; 当y小于32时,移位后的结果一般都在我们的预料当中;而如果y大于32时,由于移位超出了int所能表示的范围,这时就先把y化成二进制数,然后取该二进制数右端的低5位(相当于&11111或者是除32得到的余数),再把这5位化成十进制,此时的这个十进制就是要对X移动的位数。 例如:
int i = 1245;
String s = Integer.toBinaryString(i);
int y1 = i>>2;
String s1 = Integer.toBinaryString(y1);
int y2 = i>>34;
String s2 = Integer.toBinaryString(y2);
System.out.println(i + "->" + s + " " + y1 + "->" + s1 + " " + y2 + "->" + s2);
语句“int y2 = i>>34;”的执行过程是:先把i化成二进制数:10011011101
执行结果:
1245->10011011101 311->100110111 311->100110111
执行语句 i>> 34 对i右移34位时,先把34化成二进制:100010,对该二进制数取右边5位,即00010,化成十进制数为2,所以实际上是对i右移两位。现在,结果是:100110111
long型数据移位时一样的道理,long型一共64位,如果移动的位数超过64(2^8)就没有意义了,所以在移位前判断移动的位数是否大于64,如果大于了64则取该位数的低8位(除以64得到的余数),再移位,否则直接移位。
移位运算符和按位运算符一样,同属于位运算符,因此移位运算符的位指的也是二进制位。它包括以下几种:
左移位(<<):将操作符左侧的操作数向左移动操作符右侧指定的位数。移动的规则是在二进制的低位补0。
- 有符号右移位(>>):将操作符左侧的操作数向右移动操作符右侧指定的位数。移动的规则是,如果被操作数的符号为正,则在二进制的高位补0;如果被操作数的符号为负,则在二进制的高位补1。
- 无符号右移位(>>>):将操作符左侧的操作数向右移动操作符右侧指定的位数。移动的规则是,无论被操作数的符号是正是负,都在二进制位的高位补0。
注意,移位运算符不存在“无符号左移位(<<<)”一说。与按位运算符一样,移位运算符可以用于byte、short、int、long等整数类型,和字符串类型char,但是不能用于浮点数类型float、double;当然,在Java5.0及以上版本中,移位运算符还可用于byte、short、int、long、char对应的包装器类。我们可以参照按位运算符的示例写一个测试程序来验证,这里就不再举例了。
与按位运算符不同的是,移位运算符不存在短路不短路的问题。
写到这里就不得不提及一个在面试题中经常被考到的题目:
这里所谓的最有效率,实际上就是通过最少、最简单的运算得出想要的结果,而移位是计算机中相当基础的运算了,用它来实现准没错了。左移位“<<”把被操作数每向左移动一位,效果等同于将被操作数乘以2,同理,无符号右移位">>>"把被操作数每向右移动一位,效果等同于将被操作数除以2,而2*8=(2*2*2*2),就是把2向左移位3次。因此最有效率的计算2乘以8的方法就是“2<<3”。
最后,我们再来考虑一种情况,当要移位的位数大于被操作数对应数据类型所能表示的最大位数时,结果会是怎样呢?比如,1<<35=?呢?
这里就涉及到移位运算的另外一些规则:
- byte、short、char在做移位运算之前,会被自动转换为int类型,然后再进行运算。
- byte、short、int、char类型的数据经过移位运算后结果都为int型。
- long经过移位运算后结果为long型。
- 在左移位(<<)运算时,如果要移位的位数大于被操作数对应数据类型所能表示的最大位数,那么先将要求移位数对该类型所能表示的最大位数求余后,再将被操作数移位所得余数对应的数值,效果不变。比如1<<35=1<<(35%32)=1<<3=8。
- 对于有符号右移位(>>)运算和无符号右移位(>>>)运算,当要移位的位数大于被操作数对应数据类型所能表示的最大位数时,那么先将要求移位数对该类型所能表示的最大位数求余后,再将被操作数移位所得余数对应的数值,效果不变。。比如100>>35=100>>(35%32)=100>>3=12。
下面的测试代码验证了以上的规律:
- public abstract class Test {
- public static void main(String[] args) {
- System.out.println("1 << 3 = " + (1 << 3));
- System.out.println("(byte) 1 << 35 = " + ((byte) 1 << (32 + 3)));
- System.out.println("(short) 1 << 35 = " + ((short) 1 << (32 + 3)));
- System.out.println("(char) 1 << 35 = " + ((char) 1 << (32 + 3)));
- System.out.println("1 << 35 = " + (1 << (32 + 3)));
- System.out.println("1L << 67 = " + (1L << (64 + 3)));
- // 此处需要Java5.0及以上版本支持
- System.out.println("new Integer(1) << 3 = " + (new Integer(1) << 3));
- System.out.println("10000 >> 3 = " + (10000 >> 3));
- System.out.println("10000 >> 35 = " + (10000 >> (32 + 3)));
- System.out.println("10000L >>> 67 = " + (10000L >>> (64 + 3)));
- }
- }
运行结果:
- 1 << 3 = 8
- (byte) 1 << 35 = 8
- (short) 1 << 35 = 8
- (char) 1 << 35 = 8
- 1 << 35 = 8
- 1L << 67 = 8
- new Integer(1) << 3 = 8
- 10000 >> 3 = 1250
- 10000 >> 35 = 1250
- 10000L >>> 67 = 1250
转自:http://blog.csdn.net/chattie/archive/2009/03/27/4029922.aspx
发表评论
-
Java序列化机制和原理【转】
2011-05-18 09:14 1141序列化的必要性 Java中,一切都是对象,在分布式环境中经 ... -
JAVA反射机制的应用(2)
2010-12-07 16:28 1254JAVA反射机制的应用(2 ... -
JAVA反射机制的简单应用(1)
2010-12-06 13:15 1436JAVA反射机制的简单应用(1) Spring中的IOC ... -
java反射学习笔记
2010-12-05 10:21 1559java反射作用: 1、自省:通过对象自身获得类结构,继 ... -
Java反射笔记(2)
2010-12-02 09:46 1735java.lang.array提供了动态 ... -
Java反射笔记(1)
2010-12-01 10:54 1139感谢张龙老师的视频:http://www.verycd.com ... -
连接池的基本工作原理及简单实现
2010-11-24 21:25 918连接池的基本工 ... -
Java 继承与组合的区别
2010-11-22 10:36 7991根据网络上大家对 ... -
蛇形矩阵的java实现
2010-11-10 22:22 7890题目: 计算并输出 nXn ... -
两个矩阵的乘积的java实现
2010-11-10 16:23 8335题目: 计算两个矩阵 A、B 的乘积矩阵 C。 ... -
螺旋数组的java实现
2010-11-10 15:26 2099螺旋数组 要求:存储和输出nXm的螺旋数组,其中n和m为 ... -
统计一个整数中出现次数最多最大的数字
2010-11-10 09:31 6548要求: 统计一个整数中出现最多的数字。如果数字个数 ... -
“百元买百鸡问题”之一重循环实现
2010-11-09 10:06 3710问题描述: 每只母鸡 3 元,每只公鸡 4 元,每只小鸡 0 ... -
[转]欧几里得算法(辗转相除法)求最大公约数
2010-11-08 22:52 2870欧几里德算法又称辗转相除法,用于计算两个整数a,b的最大公约数 ... -
[转]深入理解自增自减运算符a=a++和a=++a
2010-11-07 23:04 3237更深入地理解自增自减运算符 首先贴一个非常简洁却 ... -
笔试题之以单词为最小单位翻转字符串
2010-11-06 15:39 2394最近做了几个公司 ... -
java解惑之无穷大和NaN
2010-11-01 10:12 17851、i == i + 1 一个数字永远不会等于它自己加1 ... -
java 死锁及解决
2010-10-31 21:28 1126Java线程死锁如何避免 ... -
深入Java关键字null
2010-10-31 14:20 839深入Java关键字null ... -
对java中equals和hashCode函数的一些理解2(转)
2010-10-31 11:24 1052一致性 即如果两个对象相等的话,那么它们必须始终保持相等,除非 ...
相关推荐
在Java中,所有的整数类型(除了char类型外)都是有符号的,这意味着它们能表示正数和负数,而负数使用2的补码表示。 **2的补码表示法**: 在2的补码表示法中,负数的二进制形式是其正数对应值的二进制位取反后再加...
在Java语言中,位运算符可以应用于所有整型数据类型,如`long`、`int`、`short`、`char`和`byte`。位运算在很多场景下非常有用,例如优化算法性能、实现高效的数据结构等。 #### 二、位运算符 Java中的位运算符...
switch语句是JAVA中的一个选择结构,类型可以是int, short, byte, char, enum这五个类型,enum必须是JDK5.0。 JAVA学习笔记涵盖了JAVA的基础知识和面向对象编程思想,帮助学习者更好地理解和使用JAVA语言。
5. Java中的switch语句可以作用于byte、short、char、int以及枚举类型的对象,不能作用于long和String类型。 6. 在Java中,使用short类型时,如果进行加1操作,由于自动类型提升会引发编译错误。但使用"short s1 += ...
- 在Java中,一个源文件可以包含多个类,但最多只能有一个公共类(public class),且公共类的名称必须与文件名相同。非公共类(非public)不受此限制,可以在同一个源文件中定义多个。 2. **Java 有没有 goto?** ...
Java 语言提供了八种基本数据类型,包括整数类型(byte、short、int、long)、浮点数类型(float、double)、字符类型(char)、布尔类型(boolean)。每种数据类型都有其特定的范围和默认值。 2. 字符串 Java 语言...
- char型变量可以存储中文汉字,因为UTF-16编码中,一个汉字通常占用两个字节,而char在Java中恰好表示一个16位的Unicode字符。 8. 有效率地计算2乘以8: - 最简单的方法是直接使用`2 * 8`,Java会自动进行算术...
5. java 中的 char 类型可以表示 0~65535 个字符,利用 Unicode 编码格式。 6. 可以使用单引号字符或者整数对 char 型赋值。 7. java 中小数常量被认为 double 型,若要表明为 float 型,在其后加 f。 8. float 是 4...
8. **高效计算2乘以8**:在Java中,最简单且高效的方式是使用移位运算符`,即`2 ,这相当于2乘以2的3次方,即2*8。 9. **设计大整数计算器**:设计一个能处理百亿级别数字的计算器,需要考虑使用BigInteger类,该类...
5. switch语句在Java 7之后可以作用于String类型,而byte和long类型在Java中也可以用switch进行操作。 6. 在Java中,short类型的变量如果进行算术运算后赋值给short,需要进行类型转换。 7. char型变量可以存储...
3. 在Java中,基本数据类型包括byte、short、int、long、char、float、double和boolean。其中char类型用于存储单个字符,占用两个字节,因此能够存储Unicode编码的中文字符。 4. Java的String类型不是基本数据类型...
在Java中,移位操作符对char、byte或者short类型的数值进行移位处理时,会转化成int类型,再进行移位的处理。 Java的三元操作符 Java的三元操作符是一种特殊的操作符,功能和if-else类似。它可以根据条件表达式的...
1. **基本数据类型**:Java语言有八种基本数据类型,它们分别是byte、short、int、long、float、double、boolean和char。其中,byte类型占用1个字节,short类型占用2个字节,int和float类型占用4个字节,而long和...
- **描述**: `switch` 语句可以作用在 `byte`、`short`、`char`、`int` 类型以及它们对应的包装类和枚举类型上,但不支持 `long` 和 `String` 类型。 - **应用场景**: 在编写需要根据固定类型进行选择的程序时,使用...
* 在Java中,文献名必要与被声明为public类相似,因此在Java文献中,最多只能有一种public类 * Java解释器加载是类,因而,对类名大小写是敏感的 * /* */这种注释可以自动生成一种注释文档 * 当定义了classpath后,...
- 早期版本的Java中,`switch`仅能作用于`byte`、`short`、`char`、`int`及其对应的封装类,以及枚举类型。 - Java 7引入了对`String`的支持,因此`switch`现在也可以作用于`String`类型。 6. **`short`类型变量...
7. **移位运算符**:Java中的无符号右移`>>>`运算符,将数字向右移动指定的位数。`a >>> 2`表示将8向右移动2位,结果是2。 8. **条件语句**:这个程序段的执行会根据条件判断,由于`a=3`,所以第二个`if`语句成立,...
在 Java 中,进行移位运算时,因为 int 是占 32 位,进行移位的数是 32 的模,long 占 8 字节也就是 64 位,所以移位的数是 64 的模,byte、short 进行右移位运算,会自动转换成 int 类型。 12. 左移运算 左移运算...
5. **switch语句的适用范围**:在Java中,switch可以作用于byte、char、short和int类型,以及枚举类型(Java 5以后)。自Java 7开始,switch还可以作用于字符串(String)。 6. **short变量的加法**:`short s1 = 1...
运算符是Java中实现各种操作的关键,包括算术运算符、比较运算符、逻辑运算符、位运算符、移位运算符和三目运算符。例如,算术运算符包括加、减、乘、除和取余;比较运算符用于比较两个值的大小;逻辑运算符如&&...