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(),分别接受int或long型的参数,并用二进制格式输出。
7. 窄化转换,存在信息丢失的危险,必须显式的进行转换,扩展转换着没有要求。
8. 将float或double类型转换为整型时,总是对该数字执行截尾,如果希望得到舍入的结果,就需要使用java.lang.Math中的round()方法。
9. Java中没有sizeof:没有用的需求,因为所有数据类型在机器中的大小是相同的。
10. 对char、byte和short中任何一个进行算术运算,都会得到一个int结果,必须显式的类型转换才能转换回原来的类型。