1.5 单精度浮点型float
单精度浮点型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;
1.6 双精度型double
双精度浮点型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,感兴趣的话,可以百度了解下;
1.7 长整型long
长整型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;
1.8 布尔型boolean
布尔型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位)
2.1 自动转换类型
当两种基本数据类型做运算时,最终的结果自动提升为位数空间比较大的那个类型
例如:
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等开发工具,都会自动编译报错,如有需要使用强制转换类型即可,这个问题不大~
2.2 强制转换类型
当两种基本数据类型做运算时,最终的结果会自动提升为位数空间比较大的那个类型,如果我们想要让结果是位数空间比较小的那个类型,就需要进行强制转换~
例如,前面讲到的直接用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 |
类型转换?
当两种基本数据类型做运算时,最终结果会自动转为位数空间大的那个类型,如果想要最终结果为位数空间小的类型,可以通过强制转换符
(类型)
指定括号里面的类型来实现。
原创不易,觉得有用的小伙伴来个三连(点赞+收藏+评论 )+关注
支持一下,非常感谢~
一、网安学习成长路线图
网安所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
二、网安视频合集
观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
三、精品网安学习书籍
当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。
四、网络安全源码合集+工具包
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
五、网络安全面试题
最后就是大家最关心的网络安全面试题板块