好好学Java:从零基础到项目实战
上QQ阅读APP看书,第一时间看更新

2.1.1 数值变量的类型

如今个人计算机的配置越来越高,内存和硬盘的容量大小都是以GB为单位的,而1GB=1024MB=1024×1024KB=1024×1024×1024字节。不过在PC的早期发展阶段,计算机的存储空间却是十分有限的,像2000年前后广泛使用的3.5寸软盘,其存储容量只有区区1.44MB,当时流行的SDR内存容量也才32MB和64MB。所以早期的编程语言很注重节约存储,给每个变量分配空间都要精打细算,大环境如此,于是早在1996年诞生的Java语言也不例外,仅仅是处理整数和小数就分成了byte、short、int、long、float、double六种数值类型。

下面简要介绍一下这6种类型的数值表示范围。

1.byte:字节型

该类型的变量只占用一字节大小,一字节可表达8位的二进制数,因为8位的第一位是符号位,为0时表示当前是正数,为1时表示当前是负数,所以byte类型实际囊括的数值范围是-128~127。其中,00000000~01111111表示0~127区间,而10000000~11111111表示-128~-1区间。需要注意的是,Java使用补码表示二进制数,且正数的补码与其原码相同,但负数的补码是在其反码的末位加1(负数的反码是正数)。因此,假设某负数为x,若令“x取反+1=10000000”,则求得 “x=(10000000-1)再取反=01111111取反=10000000”,即x=-128(对应10000000);若令“x取反+1=11111111”,则求得“x=(11111111-1)再取反=11111110取反=00000001”,即x=-1(对应11111111)。

2.short:短整型

该类型的变量占用两字节大小,可表达的数值范围是-32768~32767,即-215~215-1。

3.int:整型

该类型的变量占用4字节大小,可表达的数值范围是-2147483648~2147483647,即-231~231-1。

4.long:长整型

该类型的变量占用8字节大小,可表达的数值范围是-9223372036854775807~9223372036854775808,即-263~263-1。

5.float:浮点型,用来表示小数

该类型的变量占用4字节大小,它包括一个符号位、一个8位的指数和一个23位尾数,此时1+8+23=32位=4字节。浮点数的计算公式为:正负符号*(2的指数次方)*尾数,其中正负由符号位决定,8位指数的表示范围是-128~127,尾数表示一个介于1.0和2.0之间的小数。这样float类型可表示的整数部分范围横跨±3.402823×1038,小数部分范围低至1.401298×10-45,虽然看起来浮点数的表示位数大大增加,但是有效数字只有6~7位,也就是说,开头6~7位才是精确的数字,后面的数字统统不准。

6.double:双精度型,用来表示小数

该类型的变量占用8字节大小,它包括一个符号位、一个11位的指数和一个52位尾数,此时1+11+52=64位=8字节。double类型可表示的整数部分范围横跨±1.797693×10308,小数部分范围低至4.9000000×10-324,并且有效数字提高到了15~16位。跟double类型相比,float类型的有效位数明显不够,因此浮点数也被称作单精度数。

对于实际开发来说,byte和short类型可表达的整数范围太小,同时现在计算机的存储容量毫不在乎几字节的差异,因此这两个类型在Java编程中基本无用武之地。int类型可以表示高达21亿的整数,能够应付大部分的整数运算场景,故而Java编码中的整数变量最常使用int类型。至于long类型可表示多达19位的十进制数,常用于int类型覆盖不到的整数场合,比如世界人口数量80亿必须通过long类型来存储。小数计算方面,因为float类型的数字精度不够准,所以小数变量更常使用double类型来处理。

有了这些基本的数值类型,就能声明相应类型的变量了,声明语句的格式为“变量类型变量名称;”。若在声明变量时就初始化赋值,则声明语句的格式为“变量类型变量名称=具体的数值;”。下面是一个声明数值变量的代码例子,其中包含先声明再赋值和声明时即刻赋值两种情况(完整代码见本章源码的src\com\arithmetic\numerical\Basic.java)。

public class Basic {
    public static void main(String[] args) {
        int zhumulanma;  // 先声明变量
        // 8844是2005年中国测量得到的珠穆朗玛峰岩面高度,8848是冰雪高度
        zhumulanma=8844;  // 再对变量赋值
        System.out.println("珠穆朗玛峰的高度="+zhumulanma);
        double yuanzhoulv=3.1415926;  // 在声明变量之时就初始化赋值
        System.out.println("圆周率="+yuanzhoulv);
    }
}

上述代码的运行日志如下:

珠穆朗玛峰的高度=8844

圆周率=3.1415926