总结
在清楚了各个大厂的面试重点之后,就能很好的提高你刷题以及面试准备的效率,接下来小编也为大家准备了最新的互联网大厂资料。
其实在oracle的官方文档中也有对boolean类型进行了简单的描述: boolean类型只有两种可能的值-真或假,这个数据类型用于做真假条件的简单标记跟踪,它的作用仅是用来标识这一个信息,但是它的大小并不是精确定义的。
官方文档中对boolean也没有给出明确的大小定义,但是在JAVA虚拟机书籍中又说明了boolean是占用4个字节的,由此我们也能得出一个结论:boolean占用的存储空间实际上取决于JAVA虚拟机的具体实现来决定,1个还是4个字节都是存在可能性的,背后的逻辑其实是对执行效率和存储空间的一个取舍。
byte、short、int、long都被归纳到整数类型中,它们的主要区别是能够描述的数值范围不一样,这样区分的目的主要是为了节省存储空间,因为表示的范围越大,需要占用内存的空间就越多,将整数类型划分为多种,可以让我们在编程的时候根据具体情况节省存储空间,表示范围从小到大依次为:byte < short < int < long。
如果定义的数值超越了具体数据类型的可以容纳值的范围(如用byte类型接收它范围之外的int类型的值),则会出现溢出,得到的结果是一个莫名其妙的值,这个因为涉及到的知识比较深,在有了一定基础后再继续进行讲解。
byte类型
byte类型属于整数类型的一种,它的特点是来表示取值范围较小(-128 到127),就好像我们生活中的单车,一般只能承载1到2个人乘坐。
使用举例:
- 定义年龄为12岁:byte age = 12;
占用大小:1byte,8位
short类型
它也属于整数类型中的一员,不过它能够表示的范围比byte类型更大(-215 ~ 215-1),使用生活例子类比,它就像生活中的面包车,能够承载10到15人左右乘坐。
使用举例:
-
变量定义:short mobilePhone = 10086
-
可以转换成byte类型:short age = 100; byte byteAge = (byte)age;
占用大小:2byte,16位
int类型
它是整数类型中最常用到的数据类型,能够代表的取值范围为:-231 ~ 231-1,使用生活的例子来类比,它就像运货物的货车,能够承载50到100人左右。
使用举例:
-
变量定义:int money = 1000
-
可以转换成byte、short类型,但是必须是在这两种类型的取值范围内,否则会出现溢出的情况。
占用大小:4 byte, 32位
long类型
它是整数类型中能代表取值范围最大的数据类型,取值范围为: -263 ~ 263-1,用生活的例子来类比,它就像我们常坐的动车、高铁,能够承载100人以上。
特点:在定义一个数值为long类型时,需要在这个数值后面添加字母l或者L来标识,建议是使用大写字母L标识,因为小写字母l会很容易和数值1混淆。
使用举例:
-
常量定义:long testLong = 1000L;
-
可以转换成byte、short、int类型,但是必须是在这些类型的取值范围内,否则会出现溢出的情况。
占用大小:8 byte, 64位
char类型
它表示使用单引号括起来的Unicode表中的任意一个字符,没有负数的char,取值范围为:0 ~ 65535。 char类型的变量在内存中实际上存储的是字符对应的Unicode排序位置**,如定义字符char demo = ‘a’,实际上demo在内存中存储的值是97(97是字符a在Unicode编码中的排序位置)。
如果想得到一个字符对应的Unicode排序位置,可以使用int类型显示转换,即使用int类型接收char字符类型的值,如:int p = ‘a’(此时p得到的值就是97)。
使用举例:
- 变量定义:char home = ‘家’
占用大小:2 byte, 16位
Unicode编码表如下:
浮点类型代表的就是实数(即有理数和无理数的总称,更直地的说就是有限小数和无限小数的集合),在JAVA中区分为float类型和double类型。
float类型
float类型变量,在内存中需要占用4个字节,共32位(bit),它能够表示的数值范围是:-3.402 823*1038 ~ 3.402 823*1038,在存储float类型变量时保留8位有效数字(有效数字是指从左边第一个不为零的数起到最后不为零的数止),但是实际的精度取决于具体的数值,定义时需要使用字母f或者F标识。
使用举例:
- 变量定义:float money = 3.14f;
double类型
在内存中占用8个字节共64位,它能够表示的取值范围为:-1.7977*10308 ~ 1.7977*10308,在存储double类型数据的时候最大能够保留16位有效数值,实际的精度要取决于具体的数值。 在JAVA中,默认小数类型就是double,一般也使用d或者D来表示它是double类型。
使用举例:
- 变量定义:double money = 3.14或者double = 123.5D;
| 类型 | 关键字 | 占用字节 | 适用场景 | 取值范围 |
| — | — | — | — | — |
| 字节类型 | byte | 1 | 适用取值范围很小的数 | -128 ~127 |
| 短整形 | short | 2 | 较小的整数 | -215 ~ 215-1 |
| 整形 | int | 4 | 一般整数 | -231 ~ 231-1 |
| 长整型 | long | 8 | 非常大的整数 | -263 ~ 263-1 |
| 浮点型 | float | 4 | 普通实数 | -3.402 823*1038 ~ 3.402 823*1038 |
| 双精度 | double | 8 | 非常大的实数 | -1.7977*10308 ~ 1.7977*10308 |
| 字符型 | char | 2 | 单个字符 | 0-65535 |
| 布尔类型 | boolean | 1(具体取决于虚拟机实现) | 只有真或假取值 | true和false |
通过上文可以了解到,表达同一种含义的可以用多种类型表示(如整数类型有:byte、short、int、long),区别在于它们占用的空间以及可以表示的范围不一样。在JAVA中,一种数据类型变成另外一种数据类型被称之为转换,转换过程中也会涉及到数据转换。
常见的基础数据类型精度由低到高可以排序为:byte、short、char、int、long、float、double。当我们将低精度的数据类型赋值给高精度的数据类型时,系统会自动完成数据类型的转换(类比思想:将小容量的物体存放到大容量的容器中,当然是没有问题的),如:
但如果需要将高精度的类型转换成低精度的类型,那么就会出现精度的丢失,所以必须显示指定类型转换,格式如下:(需要转换的类型)要转换的值
总结
阿里伤透我心,疯狂复习刷题,终于喜提offer 哈哈~好啦,不闲扯了
1、JAVA面试核心知识整理(PDF):包含JVM,JAVA集合,JAVA多线程并发,JAVA基础,Spring原理,微服务,Netty与RPC,网络,日志,Zookeeper,Kafka,RabbitMQ,Hbase,MongoDB,Cassandra,设计模式,负载均衡,数据库,一致性哈希,JAVA算法,数据结构,加密算法,分布式缓存,Hadoop,Spark,Storm,YARN,机器学习,云计算共30个章节。
2、Redis学习笔记及学习思维脑图
3、数据面试必备20题+数据库性能优化的21个最佳实践
v6v6F-1714862565124)]
2、Redis学习笔记及学习思维脑图
[外链图片转存中…(img-YDaY6Ekg-1714862565124)]
3、数据面试必备20题+数据库性能优化的21个最佳实践
[外链图片转存中…(img-oYocl2iY-1714862565124)]