《Thinking In Java》笔记(1)
2012-07-21 11:47
288 查看
1. String 类支持“+”和“+=”. 作为连接符。
String S;
S=”abc”+”abc”; //S=”abcabc”
S+=”abc”; //S=”abcabcabc”
2. 所以倘若“从一个对象到另一个对象”赋值,实际就是将句柄从一个地方复制到另一个地方。这意味着假若为对象使用“C=D”,那么C 和D 最终都会指向最初只有D 才指向的那个对象。
3. 通过Random 对象,程序可生成许多不同类型的随机数字。做法很简单,只需调用不同的方法即可:nextInt(),nextLong(),nextFloat()或者nextDouble()。若随同随机数生成器的结果使用,模数运算符(%)可将结果限制到运算对象减1 的上限(本例是99)之下.
// '%' limits maximum value to 99:
j = rand.nextInt() % 100;
v = rand.nextFloat();
所有模数运算遵守c=a%b=a-(a/b)*b
4. 检查对象是否相等.关系运算符==和!=也适用于所有对象.
P66
但尽管对象的内容相同,句柄却是不同的,而==和!=比较的正好就是对象句柄。
若想对比两个对象的实际内容是否相同,又该如何操作呢?此时,必须使用所有对象都适用的特殊方法equals()。但这个方法不适用于“主类型”,那些类型直接使用==和!=即可。
5.移位运算符
移位运算符面向的运算对象也是二进制的“位”。可单独用它们处理整数类型(主类型的一种)。左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补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 的结果
String S;
S=”abc”+”abc”; //S=”abcabc”
S+=”abc”; //S=”abcabcabc”
2. 所以倘若“从一个对象到另一个对象”赋值,实际就是将句柄从一个地方复制到另一个地方。这意味着假若为对象使用“C=D”,那么C 和D 最终都会指向最初只有D 才指向的那个对象。
3. 通过Random 对象,程序可生成许多不同类型的随机数字。做法很简单,只需调用不同的方法即可:nextInt(),nextLong(),nextFloat()或者nextDouble()。若随同随机数生成器的结果使用,模数运算符(%)可将结果限制到运算对象减1 的上限(本例是99)之下.
// '%' limits maximum value to 99:
j = rand.nextInt() % 100;
v = rand.nextFloat();
所有模数运算遵守c=a%b=a-(a/b)*b
4. 检查对象是否相等.关系运算符==和!=也适用于所有对象.
P66
但尽管对象的内容相同,句柄却是不同的,而==和!=比较的正好就是对象句柄。
若想对比两个对象的实际内容是否相同,又该如何操作呢?此时,必须使用所有对象都适用的特殊方法equals()。但这个方法不适用于“主类型”,那些类型直接使用==和!=即可。
5.移位运算符
移位运算符面向的运算对象也是二进制的“位”。可单独用它们处理整数类型(主类型的一种)。左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补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 的结果
相关文章推荐
- 复习《Thinking in Java》笔记四:第十二章笔记 异常处理
- 《thinking in java》笔记11- static
- 《Thinking in Java》笔记 - 第五章 - 初始化与清理
- Thinking in Java笔记4
- #Thinking in Java阅读笔记# 第九章 接口
- day7 part1:《Thinking in Java》笔记第八章---多态
- 《Thinking in Java》学习笔记-----第1章 对象导论
- 《Thinking in Java》 学习笔记---多态?晚绑定。
- Thinking in java 笔记(二) -- 初始化和销毁
- thinking in java 14章 类型信息 学习笔记
- 《thinking in java》笔记2-Random()和seed
- 《thinking in java》笔记5-重写,覆盖,重载
- 《thinking in java》笔记13-内部类
- 《thinking in java》笔记17 -Array数组
- 《thinking in java》笔记7-枚举
- 《Thinking in Java》学习笔记-----第6章 访问权限控制
- Thinking in Java 第二章笔记
- 《thinking in java》笔记12-接口中的字段和变量
- thinking in java 笔记 思维导图 第六章 访问权限控制
- java线程协作---错失的信号(thinking in java 笔记)