整数运算即使是除法运算,也是精确的,两个整数相除只能得到结果的整数部分。
int x = 12345 / 67; //184
求余运算用%
int y = 12345 % 67; //17
注意:整数的除法对于除数为0时运行时将报错,但编译不会出错。
1.溢出
计算结果超出范围会发生溢出,但不会出错,会得到奇怪的结果。
public class Main{
public static void main(String[] args){
int x = 2147483640;
int y = 15;
int sum = x+y;
System.out.println(sum);//-2147483641
}
}
可以用转换成二进制的方法来看这个问题。
将类型变为long型,结果就不会溢出。
2.自增/自减
++n: 先加1再引用n
n++: 先引用n再加1
3.移位运算
int n = 7;
int a = n << 1;// 整数7左移一位得到整数14
int b = n << 2;// 整数7左移两位得到整数28
int a = n >> 1;//整数7右移一位得到整数3
int b = n >> 2;//整数7右移两位得到整数1
int n = -536870912;//对于负数,最高位的1保持不变,仍是负数。
int a = n >> 1;//-268435456
int b = n >> 2;//-134217728
int n = -536870912;//使用>>>,符号位跟着动,负数变正数
int a = n >>> 1;//1879048192
int b = n >>> 2;//939524096
对于byte和short进行移位时,会首先转换为int再进行位移。
4.位运算
按位进行与、或、非和异或的运算。对应的是二进制里面的1和0
异或:两个数不同,结果为1,否则为0。
5.运算优先级
()
!~ ++ --
*/ %
+-
<< >> >>>
&
|
+= -= *= /=
6.类型自动提升与强制转型
如果参与运算的两个数类型不一致,计算结果为较大类型的整数。小变大会自动。
大变小:强制类型转换
int i = 12345;
short s = (short) i; //12345
超出范围的强制转换会得到错误的结果。