整数运算即使是除法运算,也是精确的,两个整数相除只能得到结果的整数部分。

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

超出范围的强制转换会得到错误的结果。