数据类型的总结

1.为什么需要定义数据类型???

2.为什么需要定义变量存储区域的大小?

变量是内存中的一个存储区域。而数据类型的定义决定了这块存储区域的大小。

3.为什么需要定义变量存储区域的大小?

答:以结果为导向来分析:

Java的整数类型分为4种:byte,short,int,long。

四种的区别在于占用的存储空间不一样。

byte占用1个字节,short占用2个字节,int占用4个字节,而long占用8个字节。

5什么是字节?

字节是一种存储单位的度量。1个字节等于8位。

6.什么是位呢?

位可以理解为计算机的最小单位:0或者是1。也就是是说1个字节是8个0和1的排列组合:

比如说:00000000,00000001,00000011,…11111111。

那么在这种情况下1个字节可以表示多大的数呢?

00000000转换为十进制依然是0,11111111转换为十进制是255。

转换工具:https://tool.lu/hexconvert/

也就是说,一个字节最大可以表示255而最小可以表示0。

这是无符号位的情况,如果8位表示正数和负数,那么8位可以表示的范围是多大呢?

通常情况下,用第一位来表示正负【0为正,1为负】,这样算下来8位可以表示的范围是-127到+127。

历史长河中,补码登场

上述引入符号位的8位二进制数可以理解为原码。对于正数来说,原码就是补码,而对于负数来说,保留符号位,其他原码按位取反加1所得即为补码。补码的出现使得加减法只有加法,简化了计算结构,提高运算速度。

那么8位的情况下,用补码来衡量,可以表达的范围是-128–127。

7.为什么是-128???(按照补码计算)

10000001到11111111表示的范围是1到127,01111110到00000001表示的范围是-1到-127。

而00000000属于负数,按位取反加1的结果是10000000表示的数值是-128,但是00000000是负数。

所以8位二进制数在计算机里存储的范围是-128–127。

回到刚刚字节的问题,1字节等于8位而八位可以表示-128–127。这是byte类型的表示范围。

那如果我想用计算机计算1000加上1000,byte明显是不可用的。因为byte表示不了1000这个数值。

而short类型的存储空间为2个字节,也就是16位。对于short数据类型来说,能表示多大的数呢?

根据8位的表示范围推算:- 2的15次方到2的15次方-1=={-32768–32767}

以此类推,int为4个字节,long为8个字节,能表示的数更大。

Java通过定义变量的类型来规定变量的内存空间大小,通过阶梯式的定义,既有满足小数值运行的byte类型,也有支持大数值运算的long类型。这样不仅满足运算的最大支持(long),同时也能节省系统内存资源(byte)。

总结:数据类型的区分是一种实现面向对象的分类对比和系统资源分配优化的方案。有了数据类型,可以研究世界复杂的熵变。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值