第五课,java基本数据存储

目录

1.java八大数据类型:

 2.各个整型和浮点型的存储需求以及取值范围

3.基本类型的数据在java中存储模式:

 4.java源码、反码、补码

5、为什么byte类型127+1是 (-128)



1.java八大数据类型:

java作为强类型的语言,它的数据类型有严格的分明。在java中一共有8种基本数据类型。java类型数据就是在了内存中开辟了不同形式的内存空间

 2.各个整型和浮点型的存储需求以及取值范围

0

3.基本类型的数据在java中存储模式:

 4.java源码、反码、补码

int a=10;
byte a=127+1;
--------------------byte

--源码
45=32+8+4+1=00101101  
-45=10101101

======================

反码:正数的反码等于源码,负数的反码等于符号位不变,其余为按位取反
45:00101101
-45:11010010
相加为反码的:11111111
      变源码10000000=-0

=================================
补码:正数的补码等于源码,负数的补码等于反码基础上末尾加1
45:00101101
-45:11010011
相加为100000000等于0
=================
计算机存储一般以补码形式存储

10000000 11111101  11111110 11111111 00000001 00000010 00000011      01111111
   -128            -3              -2             -1              0               1                2                  127
                                     存储范围:   -128~127

5、为什么byte类型127+1是 (-128)

public static void main(String[] args) { byte a = 127; byte b = (byte)(a+1); System.out.println(b); }

1.计算机中对数据的二进制存储形式-------补码(下面讨讨论的皆为byte类型)

原码:45:00101101 -45:10101101

在最高位代表符号位区分正数还是负数,0代表正数,1代表负数

反码:45:00101101 -45:11010010

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

补码:45:00101101 -45:11010011

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

2.为什么计算机设计反码?

因为计算机只有加法没有减法,在做减法运算的时候,可以认为是加上一个负数,这样可以减少计算机电路的复杂度。使用原码进行减法运算会出现问题,例如计算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的问题

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

先看下图

0

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

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

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值