Java基础——数据类型

Java语言是强类型语言,对于每一种数据都定义了明确的具体数据类型,在内存中分配了不同大小的内存空间

1、原码补码反码概念

原码:就是二进制定点表示法,即最高位为符号位,“0”表示正,“1”表示负,其余位表示数值的大小。

反码:正数的反码与其原码相同;负数的反码是对其原码逐位取反,但符号位除外。

补码:正数的补码与其原码相同;负数的补码是在其反码的末位加1。 (也有说法是负数的补码等于他的原码自低位向高位,尾数的第一个‘1’及其右边的‘0’保持不变,左边的各位按位取反,符号位不变。只是刚好补码等于反码末尾+1)

2、基本数据类型分类(4类8种)

     整数型
        byte 占一个字节  -128到127
        short 占两个字  -2^15~2^15-1
        int 占四个字节 -2^31~2^31-1
        long 占八个字节 -2^63~2^63-1
    浮点型
        float 占四个字节 -3.403E38~3.403E38  单精度
        double 占八个字节-1.798E308~1.798E308 双精度
    字符型
        char 占两个字节 0~65535
    布尔型
        boolean   
            boolean理论上是占八分之一个字节,因为一个开关就可以决定是true和false了,但是java中boolean类型没有明确指定他的大小   

3、数据类型转换

隐式转换:取值范围小的数据类型与取值范围大的数据类型进行运算,会先将小的数据类型提升为大的,再运算 

强制转换:如果超出了被赋值的数据类型的取值范围得到的结果会与你期望的结果不同(精度丢失) 

4、位运算

一个数据对另一个数据位异或两次,该数本身不变(两个数交换,a = a ^ b; b = b ^ a; a = a ^ b;)

运算都是转成补码来运算,正数的补码等于它本身,所以精度损失也可以用二进制来解释((byte)-129 = -127,(byte)128 = -128 )

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值