运算符--原码、反码、补码

运算符--原码、反码、补码

原码:

十进制数据的二进制表现形式,最左边是符号位,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
posted @ 2023-12-22 19:46  Y423x  阅读(70)  评论(0编辑  收藏  举报