四.进制转换
- 十进制转二进制
计算机使用二进制数表示数值。需要将十进制数转化为二进制数进行存储和计算。
公式: 整数部分:除以2取余
小数部分:乘以2取整
例如:十进制数97转为byte类型的二进制01100001
- 二进制转十进制
二进制转十进制采用幂加和方式,从小数点左侧第一位为0次幂,小数点左侧第二位为1次幂,以此类推。当查看的位数为1时,则计算,当查看的位数为0时,则不计算。
例如:01100001.转化为十进制数,该数值第1位、第6位和第7位的值为1,则最后的结果为1 + 32 +64 = 97
二进制转换为八进制和十六进制则简单许多,当转换为八进制时,以小数点为界,分别往前和往后三位在一起进行运算;当转换为十六进制时,以小数点为界,分别往前和往后四位在一起进行运算。
例如:01100001.转化为八进制数,分别从后往前三位一次运算为 1 ,7, 1,最后结果为171;
例如:01100001.转化为十六进制数,分别从后往前四位一次运算为 1,8最后结果为81;
- 补码
补码是计算机用于规范计算的一种二进制表示方式,由于计算机使用数值的第一位来表示数据的正负,例如:00000011表示+3,而10000011表示-3,这些非0数值在逻辑上的表示都是没有问题的,这中表示方法称为源码表示法。但是用00000000表示+0,而10000000表示-0,则出现逻辑上的偏差,即:+0 不等于 -0。
为了解决这个问题,提出了补码表示法。
补码的计算公式: 正数:源码、反码和补码都相同。
负数:补码 = 反码(符号位保持不变) + 1
注意:负数在计算补码的时候,在源码取反的过程中要保留符号位不变,其他位取反,例如:10001010取反11110101(第一个1不变)。
五.Java运算符
Java语言支持如下运算符:
算术运算符:+、-、*、/、%、++、- -
赋值运算符:=、+=、-=、*=、/=等等
位运算符:~、&、|、^ 逻辑运算符:!、&&、||
关系运算符:>、<、>=、<=、= = 、!=
移位运算符>>、<<、>>>(无符号右移)
- 算数运算符
加减运算符:+、-。例如:2+39、 908.98-23 等。
乘、除和取余运算符:*、/、%。例如:2*3、908.98/23、5%2 等。
自增、自减运算符: ++、--。运算符放在变量前面,则先计算再使用;否则先使用再计算。
注意:Java按照运算符两边最高精度保留结果,即如果int类型数据与float类型数据进行运算,结果为float类型。
三目运算符:三目运算符语法如下:<逻辑表达式> ? <表达式1> : <表达式2>
当逻辑表达式为真时,表达式1有效;当逻辑表达式为假时,表达式2有效。
- 赋值运算符
赋值运算符:=、+=、-=、*=、/=等
- 位运算符
位运算是将数据先转化为二进制数补码形式,再逐位(bit)按规则计算。
“按位与”运算符“&”,规则:全1则1,否则为0
“按位或”运算符“|”,规则:全0则0,否则为1。
“按位非”运算符“~”,规则:遇1则0,遇0则1。
“按位异或”运算符“^”,规则:相同为0,不同为1。
例如 按位与运算
a 00000000 00000000 00000000 00000111
b & 10000001 10100101 11110011 10101011
c 00000000 00000000 00000000 00000011
注意:按位异或运算是可逆的,即如果对某个数据a进行两次相同的异或运算,则结果会还原为a
- 逻辑运算符
逻辑运算符:
运算符 | 用法 | 含义 |
&& | op1&&op2 | 逻辑与 |
|| | op1||op2 | 逻辑或 |
! | !op | 逻辑非 |
逻辑运算符规则:
op1 | Op2 | op1&&op2 | op1||op2 | !op1 |
true | True | true | true | false |
True | False | false | true | false |
False | True | false | true | true |
False | False | false | false | true |
逻辑运算符(&&、||)与位运算符(&、|)的区别:
逻辑运算符只能针对boolean类型进行逻辑运算,而位运算还可以对数值进行逻辑运算。
逻辑运算符有短路情况,即前面的表达式可以得到最终结果时,后面的表达式将不被执行。
- 关系运算符
运算符 | 用法(表达式) | 含义 |
> | op1 > op2 | 大于 |
< | op1 < op2 | 小于 |
>= | op1 >= op2 | 大于等于 |
<= | op1 <= op2 | 小于等于 |
== | op1 == op2 | 等于 |
!= | op1 != op2 | 不等于 |
关系运算符的返回类型是布尔型,即返回关系表达式的真或假。
- 移位运算符
移位运算符有三种:
>> 右移运算符:将二进制数据进行右移运算。
<< 左移运算符:将二进制数据进行左移运算。
>>> 无符号右移运算符:无论正负,都在高位插入0。
六.java表达式
表达式是符合一定语法规则的运算符和操作数的序列。
运算符的优先级从高到低的顺序进行,优先级相同的运算符按照事先约定的结合方向进行,运算符优先级如下: