【学习背景】
相信很多初学Java的小伙伴或者已经入行的小伙伴,都知道Java的数据类型主要分为引用数据类型和基本数据类型,引用数据类型就是平时大家说的万物皆对象Object,而基本数据类型,则有八种,大家应该都记得(也可能不知道或者记不全了,哈哈哈)
如果你是Java初学者,那么当你去面试Java初级工程师岗位的时候,面试官可能会比较喜欢问这个问题,主要是想考察小伙伴们对基本数据类型了解多少,写代码时会不会乱用基本数据类型,给公司的大佬们挖坑,哈哈哈~
本文主要目的是给Java初学者或者想要加深自己对这八种基本数据类型的认识和理解的小伙伴,应届生秋招进行中了,很多刚毕业的小伙伴,当你再去面试遇到面试官让你回答【关于Java八种基本数据类型?】这个问题的时候,不要就简单的回答,Java八种基本数据类型有
byte/short/char/int/float/double/long/boolean
…OVER!!
相信学习了本文,你还可以在从这几个方面去回答,可能会更加分哇~
- 八种基本数据类型的
默认值
是多少?- 八种基本数据类型的
取值范围
是多少?- 八种基本数据类型的
占用空间
如何?- 八种基本数据类型的
相互转换
?
进入正文~
字节(byte)是计算机的基本单位,但不是最小的单位,最小的单位是位(bit)
1 byte = 8bit 即一个字节占用8位二进制~
- 默认值: 0;
- 数值范围:
(-2^7) ~ (2^7-1) 即 -128 ~ 127
;- 占用空间:
1 byte
= 8bit即一字节占用8位二进制;- 注意事项:byte在大容量数组中使用时非常节省空间,只占用int类型的四分之一;
- 代码例子:byte b1 = -127,byte b2 = 128;
短整型short 是一种比较小的整数~
- 默认值:
0
;- 数值范围:
(-2^15) ~ (2^15 - 1)
即 -32768 ~ 32767;- 占用空间:
2 byte
= 16bit即两字节占用16位二进制;- 注意事项:在大容量数组中使用相对节省空间,只占int的二分之一;
- 代码例子:short s1 = -666,short s2 = 666。
char字符型是Java非常独特的基本数据类型,占用两个字节,采用了Unicode(万国码)作为字符编码,可以存储任何字符
- 默认值:
0
(注意这里的0
是Unicode值,对应的字符是空字符串''
);- 数值范围:
0 ~ 65535
对应Unicode码\u0000 ~ \uffff
(常用字符数值,例如空字符’'对应0、'A’对应65、'a’对应97、字符数字’0’对应48);- 占用空间:
2 byte
= 16bit即两个字节占用16位二进制;- 注意事项:计算机业界为实现跨语言信息交换提供了两种比较常用的交换码,分别是ASCII(美国信息交换标准代码,范围0 ~ 127)和UNICODE(单一码或万国码,范围 0~ 65535)
- 代码例子:char c= ‘’;char c1= ‘A’;char c2= ‘a’;char c3= ‘0’;
我们平时讲的整数,在Java中指的就是int整型
- 默认值: 0;
- 数值范围:
-2^31 ~ (2^31 - 1)
即 -2,147,483,648 ~ 2,147,483,647;- 占用空间:
4 byte
(32bit)即两个字节占用32位二进制;- 代码例子:int i1 = -9999999, int i2 = 9999999。
单精度浮点型float是Java中的一种浮点型,数值后面带F或f~
- 默认值:
0.0F
(或0.0f
);- 数值范围:
-2^128 ~ 2^127
精度范围:7~8位有效数字(不用刻意记)- 占用空间:
4 byte
= 32bit即两个字节占用32位二进制;- 注意事项:
(1)在大容量浮点数组中使用比较节省空间,只占double类型的二分之一
(2)因为float浮点型是有精度的,不能用来表示精确的值,因此实际开发涉及到金钱货币的,不能用float,一般使用BigDecimal,感兴趣的话,可以百度了解下;
- 代码例子:float f1 = 123.45F;或 float f2 = 123.45f;
双精度浮点型double是Java中默认的一种浮点型,数值后面带D或d或者不带标识符的小数~
- 默认值:
0.0D
或0.0d
或0.0
;- 数值范围:取值范围:
-2^1024 ~ 2^1023
精度范围:16~17位有效数字(不用刻意记);- 占用空间:
8 byte
= 64bit即两个字节占用64位二进制;- 代码例子:double d1=7D;double d2=7d;double d3=7.0;
- 注意事项:同样double浮点型是有精度的,不能用来表示精确的值,因此实际开发涉及到金钱货币的,不能用float,一般使用BigDecimal,感兴趣的话,可以百度了解下;
长整型long,顾名思义,一般用来存储比较大的整数值~
- 默认值:
0L
(或0l,不过不建议使用小写字母l,容易与数字1混淆);- 数值范围:
-2^63 ~ (2^63 -1)
即 -9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,807;- 占用空间:
8 byte
= 64bit即两个字节占用64位二进制;- 代码例子:long l1 = -9999999999999L,Long l2 = 9999999999999L;
布尔型boolean与其他7种基本数据类型不同,只有true/false两种值,主要用来做判断条件的~
- 默认值:
false
;- 数值范围:
true/false
;- 占用空间:
1bit 或 4bit
;- 代码例子:boolean b1 = true,boolean b2 = false;
- 注意事项:关于boolean类型的true/false占用1bit还是4bit,业界并没有给出精确的定义,因为boolean编译后其实使用了int代替,而true用1表示,false用0表示,《Java虚拟机规范》中也给出了boolean占用4个字节、boolean数组占用1个字节的定义;
经过前面的学习,我们知道除了boolean类型,其他7种基本数据类型占用的位数空间由小到大为:
byte(8位) < short(16位) = char(16位) < int(32位) = float(32位) < double(64位) = long(64位)
当两种基本数据类型做运算时,最终的结果自动提升为位数空间比较大的那个类型
例如:
double d1 = 1.1;
int i1 = 1;
double value = d1 + i1;
你不能:
double d1 = 1.1;
int i1 = 1;
int value = d1 + i1;
需要注意的是,char/short、int/float及double/long两两位空间是一样大小的,并不是能全部实现自动类型转换,不过一般现在的IDE等开发工具,都会自动编译报错,如有需要使用强制转换类型即可,这个问题不大~
当两种基本数据类型做运算时,最终的结果会自动提升为位数空间比较大的那个类型,如果我们想要让结果是位数空间比较小的那个类型,就需要进行强制转换~
例如,前面讲到的直接用int接收double数值结果的错误例子:
double d1 = 1.1;
int i1 = 1;
int value = d1 + i1;
这种情况,就可以使用强制转换符(类型)
来实现:
double d1 = 1.1;
int i1 = 1;
int value = (int)(d1 + i1);
不过细心的同学,强制转换类型,可能会导致精度丢失
,比如本来是double类型的结果是2.1,强制转换为int类型后得到value变成2了,精度丢失了
byte/short/char/int/float/double/long/boolean
byte(0) /short(0) /char(
0
)/int(0)/long(0L)/float(0.0f)/double(0.0d)/boolean(false)
PS:这里需要注意的是char字符型的默认值是0
,是一个空字符''
,Unicode码对应'\u0000'
,顺便提一下引用数据类型的默认值是null
值~
byte(1字节8位)/short(2字节16位) /char(2字节16位) /int(4字节32位) /float(4字节32位) /double(8字节64位) /long(8字节64位)/boolean(1字节或4字节)
关于取值范围,我发现除了字符型char和float、double比较特殊之外,其他一般都是套用公式
-2^(位数-1)
~( 2^(位数-1) -1)
计算出来的
类型 | 取值范围 |
---|---|
char | 0 ~ (-2^16 -1) 即 0 ~ 65535 |
byte | -2^7 ~ (-2^7 -1) 即 -128 ~ 127 |
short | -2^15 ~ (-2^15 -1) 即 -32768 ~ 32767 |
int | -2^31 ~ -2^31 -1 即 -2147483648 ~ 2147483647 |
float | 取值范围:-2^128 ~ 2^127 精度范围:7~8位有效数字(不用刻意记) |
double | 取值范围:-2^1024 ~ 2^1023 精度范围:16~17位有效数字(不用刻意记) |
long | -2^63 ~ -2^63 -1 即 -9223372036854775808 ~ 9223372036854775807 |
boolean | true/false |
当两种基本数据类型做运算时,最终结果会自动转为位数空间大的那个类型,如果想要最终结果为位数空间小的类型,可以通过强制转换符
(类型)
指定括号里面的类型来实现。
原创不易,觉得有用的小伙伴来个三连(点赞+收藏+评论 )+关注
支持一下,非常感谢~