第3章 操作符

Java中有关操作符的语法大多与C++中的类似,就不再重复说了,只说下其中特殊的地方。


1. String支持“+”和“+=”操作。在进行“+”操作时,如果一个操作数是字符串,其他操作数自动转为字符串。但要注意运算顺序。例如下面两个输出是不一样的。

System.out.println(“ans”+2+3);

System.out.println(2+3+“ans”);


2. %”运算符的操作数可以是浮点数,如52.3%10的结果是2.3


3. 二元运算符的结果的数据类型一般为两个操作数中范围较大的一个。


4. 赋值相容:小范围类型赋给大范围类型会自动转换为大范围的类型。

  赋值不兼容:需要进行强制转换,可能发生精度丢失。


5. 测试对象的等价性

关系操作符==!=适用于所有的对象,但其意义是对引用的比较,所以只是用不同的引用创建值两个相等的对象,它们的比较也是false的。如下面的代码

Integer n1 = new Integer(47);

Integer n2 = new Integer(47);

System.out.println(n1==n2);

输出结果为false

那怎么比较两个对象的实际内容是否相同呢?这时必须要调用所有对象都使用的特殊方法equals(),但这个方法是不适用与基本类型的,基本类型直接使用关系操作符即可。

Integer n1 = new Integer(47);

Integer n2 = new Integer(47);

System.out.println(n1.equal(n2));

输出结果为true

但事情没有那么简单,如果我们用equals比较我们自己创建的类,又会有奇怪的结果:

class Value {

int  i;

}

public class Test {

public static void main(String args[]){

Value a1=new Value();

Value a2=new Value();

a1.i=a2.i=100;

System.out.println(a1.equals(a2));

}

}

输出结果竟然是false

这是因为equals()默认行为是比较引用,除非在自己创建的类中覆盖equals()方法,否则不能出现我们期望的结果。


6. 贴两个方法

printBinaryInt()printBinaryLong(),分别接受intlong型的参数,并用二进制格式输出。


7. 窄化转换,存在信息丢失的危险,必须显式的进行转换,扩展转换着没有要求。


8. 将floatdouble类型转换为整型时,总是对该数字执行截尾,如果希望得到舍入的结果,就需要使用java.lang.Math中的round()方法。


9. Java中没有sizeof:没有用的需求,因为所有数据类型在机器中的大小是相同的。


10. 对charbyteshort中任何一个进行算术运算,都会得到一个int结果,必须显式的类型转换才能转换回原来的类型。

上一篇:第5章(1) 构造器


下一篇:第2章番外2 令人惊喜的注释文档