运算符--原码、反码、补码
原码:
十进制数据的二进制表现形式,最左边是符号位,0为正,1为负。
利用原码对正数进行计算是不会有问题的。
但如果是负数计算,结果就出错,实际运算的结果,跟我们预期的结果是相反的。
原码的弊端:
- 利用原码进行计算的时候,如果是正数完全没有问题。
- 但是如果是负数计算,结果就出错,实际运算的方向,跟正确的运算方向是相反的。
反码:
出现的目的:为解决原码不能计算负数的问题而出现的。
计算规则:正数的反码不变,负数的反码在原码的基础上,符号位不变,数值取反,0变1,1变0。
反码的弊端:负数运算的时候,如果结果不跨0,跟实际结果会有1的偏差。
补码:
出现的目的:为了解决负数计算时跨0的问题而出现的。
计算规则:
- 正数的补码不变,负数的补码在反码的基础上+1.
- 另外补码还能多记录一个特殊的值-128,该数据在1个字节下,没有原码和反码。
注意点:计算机中的存储和计算都是以补码的形式进行的。
基本数据类型
数据类型 | 字节 | 二进制 |
---|---|---|
byte类型的10 | 1个字节 | 0000 1010 |
short类型的10 | 2个字节 | 0000 0000 0000 1010 |
int类型的10 | 4个字节 | 0000 0000 0000 0000 0000 0000 0000 1010 |
long类型的10 | 8个字节 | 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 1010 |
隐式转换
public class Test {
public static void main(String[] args) {
byet a = 10;//0000 1010
int b = a;//0000 0000 0000 0000 0000 0000 0000 1010
System.out.println(b);
}
}
强制转换
public class Test {
public static void main(String[] args) {
int a = 300;//0000 0000 0000 0000 0000 0001 0010 1100
byet b = (byet) a;//0010 1100
System.out.println(b);//44
}
}
public class Test {
public static void main(String[] args) {
int a = 200;//0000 0000 0000 0000 0000 0000 1100 1000
byet b = (byet) a;//1100 1000
System.out.println(b);//-56
}
}
其他运算符
运算符 | 含义 | 运算规则 |
---|---|---|
& | 逻辑与 | 0为false,1为true |
| | 逻辑或 | 0为false,1为true |
<< | 左移 | 向左移动,地位补0 |
>> | 右移 | 向右移动,高位补0或1 |
>>> | 无符号右移 | 向右移动,高位补0 |