一.四则运算符:+ - * /
二.增量赋值运算符:+= -= *= /=
三.关系运算符:== != > < >= <=
四.逻辑运算符(短路效应):&& ||
对比&& ||和& | 前者具有短路效应 后者不具备 不具有容错率
五.位运算符:& | ~ ^
&:如果两个二进制位都是 1, 则结果为 1, 否则结果为 0.(注意都为0结果也不是1)
int a = 10;
int b = 20;
System.out.println(a & b); //运行结果:0
我们将其转换成二进制形式并进行二进制各相同位的与运算:
|: 如果两个二进制位都是 0, 则结果为 0, 否则结果为 1.(都为1结果也是1)
int a = 10;
int b = 20;
System.out.println(a | b); //运行结果:30
同样,我们利用转化为二进制的想法进行计算
注意: 当 & 和 | 的操作数为整数(int, short, long, byte) 的时候, 表示按位运算, 当操作数为 boolean 的时候, 表示逻辑 运算.
~:按位取反 如果该位为 0 则转为 1, 如果该位为 1 则转为 0
int a = 0xf;
System.out.printf("%x\n", ~a) //运算结果:fffffff5
注意:
1. 0x 前缀的数字为 十六进制 数字. 十六进制可以看成是二进制的简化表示方式. 一个十六进制数字对应 4 个二进 制位.
2. 0xf 表示 10 进制的 15, 也就是二进制的 1111
3. printf 能够格式化输出内容, %x 表示按照十六进制输出.
^: 按位异或 如果两个数字的二进制位相同, 则结果为 0, 相异则结果为 1.
int a = 0x1;
int b = 0x2;
System.out.printf("%x\n", a ^ b); //运算结果:3
六.移位运算:
左移 <<: 最左侧位不要了, 最右侧补 0
int a = 0x10;
System.out.printf("%x\n", a << 1);
// 运行结果(注意, 是按十六进制打印的) 20
右移 >>: 最右侧位不要了, 最左侧补符号位 比特科技 (正数补0, 负数补1)
int a = 0x10;
System.out.printf("%x\n", a >> 1);
// 运行结果(注意, 是按十六进制打印的)
8
int b = 0xffff0000;
System.out.printf("%x\n", b >> 1);
// 运行结果(注意, 是按十六进制打印的)
ffff8000
无符号右移 >>>: 最右侧位不要了, 最左侧补 0
int a = 0xffffffff;
System.out.printf("%x\n", a >>> 1);
// 运行结果(注意, 是按十六进制打印的)
7fffffff
注意:
1. 左移 1 位, 相当于原数字 * 2. 左移 N 位, 相当于原数字 * 2 的N次方.
2. 右移 1 位, 相当于原数字 / 2. 右移 N 位, 相当于原数字 / 2 的N次方.
3. 由于计算机计算移位效率高于计算乘除, 当某个代码正好乘除 2 的N次方的时候可以用移位运算代替.
4. 移动负数位或者移位位数过大都没意义
七.条件运算符
条件运算符只有一个: 表达式1 ? 表达式2 : 表达式3
当 表达式1 的值为 true 时, 整个表达式的值为 表达式2 的值; 当 表达式1 的值为 false 时, 整个表达式的值为 表达式 3 的值. 其也是 Java 中唯一的一个 三目运算符, 是条件判断语句的简化写法.
int a = 10;
int b = 20;
int max = a > b ? a : b;// 求两个整数的最大值
注:运算符之间是有优先级的. 具体的规则我们不必记忆. 在可能存在歧义的代码中加上括号即可
小结:
1. % 操作在 Java 中也能针对 double 来计算.
2. 需要区分清楚 前置自增 和 后置自增之间的区别.
3. 由于 Java 是强类型语言, 因此对于类型检查较严格, 因此像 && 之类的运算操作数必须是 boolean.
4. 要区分清楚 & 和 | 什么时候是表示按位运算, 什么时候表示逻辑运算