数据类型的全家福(4+2+1+1)
java共有8种基本类型(primitive type),其中有4种整型、2种浮点类型、1种字符类型char和1种用于表示真值的boolean类型。
1.整型(4种)
类型 存储需求 取值范围
int 4字节 -2 147 483 648~2 147 483 647(削削超过 20亿)
short 2字节 -32 768 ~32 767
long 8字节 -9 223 372 036 854 775 808 ~ 9 223 372 036 854 775 807
byte 1字节 -128 ~ 127
整型用于表示没有小数部分的数值,允许是负数。
在通常情况下,int类型最常用。byte和short类型主要用于特定的应用场合,例如,底层的文件处理或者存储空间很宝贵时的大数组。
在Java中,由于Java程序必须保证在所有机器上都能够得到相同的运行结果,所以各种数据类型的取值范围必须固定。整型的范围与运行Java代码的机器无关。
长整型数值有一个后缀L或l;十六进制数值有一个前缀0x或0X;八进制有一个前缀0.
Java 没有任何无符号(unsigned)形式的int、long、short或byte类型。
2.浮点类型(2种)
类型 存储需求 取值范围
float 4字节 大约±3.40282347E+38F(有效位数为6~7位)
double 8字节 大约±1.797693134 86231570E+308(有效位数为15位)
浮点类型用于表示有小数部分的数值
double表示这种类型的数值精度是float类型的两倍(有人称之为双精度数值)
float类型的数值有一个后缀F或f(例如3.14F),没有后缀F的浮点数值(如3.14)总是默认为double类型。 当然,也可以在浮点数值后面添加后缀D或d(例如,3.14D)。
所有的浮点数值计算都遵循IEEE754规范。具体来说,下面是用于表示溢出和出错情况的三个特殊的浮点数值:正无穷大、负无穷大、NaN(不是一个数字)
例如,一个正整数除以0的结果为正无穷大。计算0/0或者负数的平方根结果为NaN。
特别说明:所有“非数值”的值都认为是不相同的。
//不能如下检测一个特定值是否等于Double.NaN
if (x m==Double.NaN) // is never true
//可以如下使用 Double.isNal方法来判断:
if (Double.isNaN(x)) // check whether x is "not a number"
1
2
3
4
3.char类型(1种)
char类型原本用于表示单个字符
如今,有些Unicode字符可以用一个char值描述,一些Unicode字符则需要两个char值。
char类型的字面量值要用单引号括起来,如'A'
```java
public static void main(String[] args) {
char c = 'A'; //字符常量值需要使用单引号囊括,并且内部只能有一个字符
System.out.println(c);
}
1
2
3
4
5
每个数字在计算机中都会对应一个字符,可以去认识一下ASCII码:
//英文字母`A`要展示出来,那就是一个字符的形式,
//而其对应的ASCII码值为65,所以说当char为65时,打印出来的结果就是大写的字母A了
public static void main(String[] args) {
char c = 65;
System.out.println(c);
}
1
2
3
4
5
6
char类型的值可以表示为十六进制值,其范围从\u0000到\uFFFF
除了转义序列\u之外,还有一些用于表示特殊字符的转义序列
转义序列 名称 Unicode值
\b 退格 \u0008
" 双引号 \u0022
’ 单引号 \u0027
\t 制表 \u0009
\n 换行 \u000a
\ 反斜杠 \u005c
\r 回车 \u000d
所有这些转义序列都可以出现在加引号的字符字面量或字符串中,如'\u2122'或"Hello\n"
转义序列\u还可以出现在加引号的字符常量或字符串之外(而其他所有转义序列不可以),如
public static void main(String[] args)
public static void main(String\u005B\u005D args)
//\u005B和\u005D分别是[和]的编码
1
2
3
1.Unicode转义序列会在解析代码之前得到处理。
例如,"\u0022+\u0022"并不是一个由引号(U+0022)包围加号构成的字符串。实际上,\u0022会在解析之前转换为",这会得到""+"",也就是一个空串。
★2.要当心注释中的\u
// \u000A is a newline会产生一个语法错误,因为读程序时\u00A0会替换为一个换行符
// look inside c:\users也会产生一个语法错误,因为\u后面并没有跟着4个十六进制数。
3.1Unicode和char类型
Unicode打破了传统字符编码机制的限制
在Unicode出现之前,已经有许多种不同的标准
这样就产生了下面两个问题:一个是对于任意给定的代码值,在不同的编码方案下有可能对应不同的字母;二是采用大字符集的语言其编码长度有可能不同。例如,有些常用的字符采用单字节编码,而另一些字符则需要两个或多个字节。
注意: Unicode 是“字符集”,也就是有哪些字符,而UTF-8、UTF-16 是“编码规则”,也就是怎么对这些字符编码,怎么以二进制的形式保存,千万不要搞混了。
4.boolean类型(1种)
boolean(布尔)类型有两个值:false和true,用来判定逻辑条件。
整型值和布尔值之间不能进行相互转换。
在C++中,数值甚至指针可以代替boolean值。值θ相当于布尔值false,非0值相当于布尔值true。在Java中则不是这样。
因此,Java程序员不会遇到下述麻烦:
if (x = 0) // cops... meant x == 0
//在C++中这个测试可以编译运行,其结果总是false
//在Java中,这个测试将不能通过编译,原因是整数表达式x=0不能转换为布尔值