Java基本数据存储

一、八种基本数据类型

java是一种强类型的语言,这就意味着每一种变量都有一种类型。在java中一共有8种基本数据类型。

java的强数据类型实质上就是在内存当中开辟不同形式的内存空间。

 

二、数据类型存储所需字节数以及取值范围

三、以byte类型为例进行讨论

例:public static void main(String[] args) {

                byte a = 127

                byte b = (byte)(a+1)

                System.out.println(b)}

1.计算机中对数据的二进制存储形式-------补码

例:

原码:45:00101101 

          -45:10101101

反码:正数的原码和反码相同,负数的反码等于原码的符号位不变,其余各位按位取反 

反码:45:00101101

          -45:11010010

正数的原码反码和补码都形同,负数的补码等于在其反码基础上末尾+1

补码:45:00101101

          -45:11010011

2.反码,补码的产生原因

简单的说引入原码、补码、反码的目的就是为了解决减法的问题,因为计算机CPU运算器中只有加法器,要把减法转换为加法来做。 比如 -15+12 可以转换成-15的补码 + 12的补码来实现 有些规则可以记一下: 1、补码 = 反码 + 1; 2、反码 = 原码除符号位之外,其余为按位取反 3、任何正数的原码、反码、补码都是一样的 4、在计算机中,有符合的数都是用补码来表示的。

例如计算1-1,因为计算机有加法没有减法,所以计算机自动换算成1+(-1)

1-1=1+(-1)=[00000001]原+[10000001]原=[10000010]原=-2 (符号位也参与运算)

与实际结果不符

1-1=1+(-1)=[00000001]原+[10000001]原=[00000001]反+[11111110]反=[11111111]反=[10000000]原=-0

通过反码计算的结果是11111111在计算一次反就成原码了,得出的结果是正确的,但是有一个问题是 00000000可以代表+0 10000000可以代表-0,其实是一样的,用2个编码实在是浪费。于是出现了补码解决0的符号以及两个编码的问题

1-1=1+(-1)=[00000001]原+[10000001]原=[00000001]补+[11111111]补=[00000000]补=[00000000]原

这样0用[0000 0000]表示, 而以前出现问题的-0则不存在了.

总结:反码是为了解决减法运算,补码是为了解决反码产生的+0,-0的问题

3.为什么byte类型127 +1 是(-128)

先看下图

由图可知,127的补码,原码,反码 都为 0111 1111,那么加上1 变成 1000 0000,此时将1000 0000(左边第一位是1,负数,取补码)转换成二进制是多少呢? 可以根据图查看,也可以根据上面的方法自己算。

1.先对各位取反,为 0111 1111

2.转成二进制 127.

3.加上负号 -127  再减去1 为 -128.所以第一次输出结果是 -128

再往下看 第二个输出是-127,怎么来的呢? 第一次加完 计算机得到 1000 0000,再加1,变成 1000 0001,转成二进制

1.先对各位取反,为 0111 1110

2.转成二进制 126

3.加上负号 -126  再减去1 为 -127.

使用补码, 不仅仅修复了0的符号以及存在两个编码的问题, 而且还能够多表示一个最低数. 这就是为什么8位二进制, 使用原码或反码表示的范围为[-127, +127], 而使用补码表示的范围为[-128, 127]。

因为机器使用补码, 所以对于编程中常用到的32位int类型, 可以表示范围是: [-2^31, 2^31-1] 因为第一位表示的是符号位.而使用补码表示时又可以多保存一个最小值。

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值