运算符
一、分类
- 算术运算符
- 关系运算符
- 位运算符
- 逻辑运算符
- 赋值运算符
- 其他运算符
1.1 算术运算符
操作符 | 描述 | 例子 |
---|---|---|
+ | 加法 - 相加运算符两侧的值 | A + B 等于 30 |
- | 减法 - 左操作数减去右操作数 | A – B 等于 -10 |
* | 乘法 - 相乘操作符两侧的值 | A * B等于200 |
/ | 除法 - 左操作数除以右操作数 | B / A等于2 |
% | 取余 - 左操作数除以右操作数的余数 | B%A等于0 |
++ | 自增: 操作数的值增加1 | B++ 或 ++B 等于 21 |
-- | 自减: 操作数的值减少1 | B-- 或 --B 等于 19 |
1.1.1 自增与自减运算符
$ 1. 前缀 、后缀 自增自减法
int a=9;int b=a++;//先让b=a 再让a++int c=++a;///先让 a++,再让c=a
$ 2. 自增(++)自减(--)运算符
面试点
int c=1;
c=c++;
System.out.println(c);
自身等于自身加加减减 是无效的 --->无效操作
1.2 关系运算符
运算符 | 描述 | 例子 |
---|---|---|
== | 检查如果两个操作数的值是否相等,如果相等则条件为真。 | (A == B)为假。 |
!= | 检查如果两个操作数的值是否相等,如果值不相等则条件为真。 | (A != B) 为真。 |
> | 检查左操作数的值是否大于右操作数的值,如果是那么条件为真。 | (A> B)为假。 |
< | 检查左操作数的值是否小于右操作数的值,如果是那么条件为真。 | (A <B)为真。 |
>= | 检查左操作数的值是否大于或等于右操作数的值,如果是那么条件为真。 | (A> = B)为假。 |
<= | 检查左操作数的值是否小于或等于右操作数的值,如果是那么条件为真。 | (A <= B)为真。 |
1.3 位运算符
应用于整数类型(int),长整型(long),短整型(short),字符型(char),和字节型(byte)等类型。
操作符 | 描述 | 例子 |
---|---|---|
& | 如果相对应位都是1,则结果为1,否则为0 | (A&B),得到12,即0000 1100 |
| | 如果相对应位都是 0,则结果为 0,否则为 1 | (A | B)得到61,即 0011 1101 |
^ | 如果相对应位值相同,则结果为0,否则为1 | (A ^ B)得到49,即 0011 0001 |
〜 | 按位取反运算符翻转操作数的每一位,即0变成1,1变成0。 | (〜A)得到-61,即1100 0011 |
<< | 按位左移运算符。左操作数按位左移右操作数指定的位数。 | A << 2得到240,即 1111 0000 |
>> | 按位右移运算符。左操作数按位右移右操作数指定的位数。 | A >> 2得到15即 1111 |
>>> | 按位右移补零操作符。左操作数的值按右操作数指定的位数右移,移动得到的空位以零填充。 | A>>>2得到15即0000 1111 |
:CPU底层:半导体电路(集成的电路多)
两个电压 相互作用 出一个电压
与或非 对应CPU里 半导体小电路。
与或非 揭示了CPU底层其实是半导体电路
位运算涉及一些算法,&和^
异或 两数交换
x---->判定 x的 二进制 从右往左 第m位 是0还是1--- 与运算
ssssssssssssss未知
用与运算计算
s s s s s s s s s s s s s s
0 0 0 0 0 0 0 0 0 0 1 0 0 0 &
---------------------------------------
0 0 0 0 0 0 0 0 0 0 1 0 0 0
x & 2^(m-1)=2^(m-1)
^ 两变量交换值,不依赖第三个变量
x ^ s =k
根据s和k,能够反推出 x
0-1=1
0-0=0
1-1=0
异或:知道其中两位时,能够推理出第三位
1.4 逻辑运算符
操作符 | 描述 | 例子 |
---|---|---|
&& | 称为逻辑与运算符。当且仅当两个操作数都为真,条件才为真。 | (A && B)为假。 |
| | | 称为逻辑或操作符。如果任何两个操作数任何一个为真,条件为真。 | (A | | B)为真。 |
! | 称为逻辑非运算符。用来反转操作数的逻辑状态。如果条件为true,则逻辑非运算符将得到false。 | !(A && B)为真。 |
1.5 赋值运算符
操作符 | 描述 | 例子 |
---|---|---|
= | 简单的赋值运算符,将右操作数的值赋给左侧操作数 | C = A + B将把A + B得到的值赋给C |
+ = | 加和赋值操作符,它把左操作数和右操作数相加赋值给左操作数 | C + = A等价于C = C + A |
- = | 减和赋值操作符,它把左操作数和右操作数相减赋值给左操作数 | C - = A等价于C = C - A |
* = | 乘和赋值操作符,它把左操作数和右操作数相乘赋值给左操作数 | C * = A等价于C = C * A |
/ = | 除和赋值操作符,它把左操作数和右操作数相除赋值给左操作数 | C / = A,C 与 A 同类型时等价于 C = C / A |
(%)= | 取模和赋值操作符,它把左操作数和右操作数取模后赋值给左操作数 | C%= A等价于C = C%A |
<< = | 左移位赋值运算符 | C << = 2等价于C = C << 2 |
>> = | 右移位赋值运算符 | C >> = 2等价于C = C >> 2 |
&= | 按位与赋值运算符 | C&= 2等价于C = C&2 |
^ = | 按位异或赋值操作符 | C ^ = 2等价于C = C ^ 2 |
| = | 按位或赋值操作符 | C | = 2等价于C = C | 2 |
N进制左移M位,都是相当于乘以N的M次方。
任何十进制都可以变成包含若干个1的二进制
110101=1+100+10000+100000
有多少个1,就能拆成多少个这些相加。
1.5.1 左移例子:
eg:
a*m,m是万亿级别的数字。
万亿 = 10^12= 10^3 * 10^3 * 10^3 * 10^3
万亿 级别的数字--->二进制40位---->最多40个1---->
加减乘除 底层 都是 位运算。
超范围计算会出现计算错误。(比如正数左移变成了负数)
1.5.2 右移
右移操作前面补的数,看符号位。若符号位是1,补1;符号位是0,补0.
1.6 三元运算符||分布运算符
variable x = (expression) ? value if true : value if false
int c=a>b?23:11;
? 前面是条件判断,如果是,等于23,如果不是,等于11
如果e(等于a+b) >8,e等于23.34 否则,11.9.