Java--重新认识八种基本数据类型,以后入职不给公司大佬挖坑_java八种基本数据类型注意事项(2)

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.0D0.0d0.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) 计算出来的

类型取值范围
char0 ~ (-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
booleantrue/false

类型转换?

当两种基本数据类型做运算时,最终结果会自动转为位数空间大的那个类型,如果想要最终结果为位数空间小的类型,可以通过强制转换符(类型)指定括号里面的类型来实现。

原创不易,觉得有用的小伙伴来个三连(点赞+收藏+评论 )+关注支持一下,非常感谢~
在这里插入图片描述

一、网安学习成长路线图

网安所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述

二、网安视频合集

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
在这里插入图片描述

三、精品网安学习书籍

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。
在这里插入图片描述

四、网络安全源码合集+工具包

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
在这里插入图片描述

五、网络安全面试题

最后就是大家最关心的网络安全面试题板块
在这里插入图片描述在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值