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

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

原码:

十进制数据的二进制表现形式,最左边是符号位,0为正,1为负。

利用原码对正数进行计算是不会有问题的。

但如果是负数计算,结果就出错,实际运算的结果,跟我们预期的结果是相反的。

原码的弊端:

  • 利用原码进行计算的时候,如果是正数完全没有问题。
  • 但是如果是负数计算,结果就出错,实际运算的方向,跟正确的运算方向是相反的。

反码:

**出现的目的:**为解决原码不能计算负数的问题而出现的。

**计算规则:**正数的反码不变,负数的反码在原码的基础上,符号位不变,数值取反,0变1,1变0。

**反码的弊端:**负数运算的时候,如果结果不跨0,跟实际结果会有1的偏差。

补码:

**出现的目的:**为了解决负数计算时跨0的问题而出现的。

计算规则:

  • 正数的补码不变,负数的补码在反码的基础上+1.
  • 另外补码还能多记录一个特殊的值-128,该数据在1个字节下,没有原码和反码。

**注意点:**计算机中的存储和计算都是以补码的形式进行的。

基本数据类型

数据类型字节二进制
byte类型的101个字节0000 1010
short类型的102个字节0000 0000 0000 1010
int类型的104个字节0000 0000 0000 0000 0000 0000 0000 1010
long类型的108个字节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
  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值