计算机诞生之初是为了科学数据的计算,编程语言则是让计算机按照我们的意愿来处理数据。这些处理的数据有很多种类,比如说数字,字符,图片,视频等等。编程语言为了更好的处理这些数据,将数据大致划分为数字类型和字符类型。不仅仅Java语言是这样划分的,其他编程语言也是这样划分的。
在Java语言中,数据类型分为基本数据类型和引用数据类型。关于引用数据类型,我们后在后面的章节中介绍。在基本数据类型中,可以分为数字型,字符型和布尔型。如下所述:
| 整数类型:byte,short,int,long
|------数字类型----------|
基本数据类型------| | 小数类型:float,double
|------字符类型:char
|
|-------布尔类型:boolean
整数类型就不用说了,它代表的就是整数数据。为什么会有多个整数类型,其实它代表了不同大小的存储空间。数据类型不仅仅表示数据的格式,还表示其空间大小。
数据要处理,就必须在计算机中进行存储。这种存储包括两种方式,一种是以文件的形式硬盘上存储(例如我们编写的Java源程序),另一种是内存上存储,主要用于传递给CPU进行计算。编程语言中数据类型表示的空间大小,指的就是内存上的存储。我们可想而知,空间大的数据类型存储的整数范围也就越大。
那么整数类型byte(字节型),short(短整型),int(整型),long(长整型)所表示的存储空间大小是多少呢?
byte 类型占据1 byte空间大小,能存储 -128到127之间的任何整数
short类型占据2 byte空间大小,能存储 -32768到32767之间的任何整数
int 类型占据 4 byte空间大小,大约能存储 -21亿到21亿之间的任何整数。
long 类型占据8 byte空间大小,大约能存储- 922亿亿到922亿亿之间的任何整数。
我们可以看到,整数类型byte,short,int,long的存储空间依次倍数地增加,所存储的整数范围也越来越大,一般情况下,我们使用int就可以了。
这里我们要说的是byte数据类型,我们可以看到它既是一种数据类型,也是一种存储空间大小的单位。当它作为一种存储空间的单位的时候,称之为“字节”。
在编程语言中,字节(byte)就是最小的存储单位,所有的数据类型的大小都是它的整数倍。一个字节(byte)到底是多大呢?它其实代表了就是8个0或1,也就是类似于“01001010”这样的二进制数字,它就是一个字节(byte)。
既然字节(byte)是最小的存储单位,那么比它大的就是KB,MB,GB,TB等等,他们之间的转换关系都是1024倍,也就是说1KB=1024byte,1MB=1024KB,1GB=1024MB,1TB=1024GB。相信大家在日常生活中,也经常看到过这几种单位。通常一张被压缩过的图片的大小大于是100KB以内,一张高清的图片大约1-3MB左右。
在使用整数类型的时候,我们只需要记住它的大小范围即可。例如,我有一个数字65000,我能用short类型进行存储嘛?当然不行,因为这个数字超出了short类型的取值范围(-32768到32767),我们应该使用int来存储它。
接下来,我们继续讲解数字类型的另一种,就是小数类型,也称之为浮点类型,它有两种,一个是单精度float,另一个是双精度double,他们代表的存储空间如下:
float 类型占据 4 byte空间大小,大约能够精确小数6位
double 类型占据8 byte空间大小,大约能够精确小数15位
浮点数的取值范围与其精度取决于它的二进制存储,浮点数在内存中是按科学计数法来存储的,一个浮点数的存储分为三部分:符号位,指数位,尾数位。因为涉及内容比较繁琐,所以我们不再详细介绍。一般情况下,我们使用double类型就足够了,而且对于一般的编程,我们不需要高精度的计算,我们能够保留小数后2位就可以了。如果是需求要求的话,我们可以精确到需求指定的位数。这里还要提醒大家的是,对于浮点型数据的计算,在计算过程中可能会丢失精度,造成结果不对,原因在于计算机小数存储和计算机制导致的。为了能保持尽量高的精度,我们可以将小数扩大为整数后在计算,最后再缩小为小数的结果。另外,