数据类型的全家福(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)。
- float类型的数值有一个后缀
- 所有的浮点数值计算都遵循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"
3.char类型(1种)
- char类型原本用于表示单个字符
- 如今,有些Unicode字符可以用一个char值描述,一些Unicode字符则需要两个char值。
- char类型的字面量值要用单引号括起来,如
'A'
```java
public static void main(String[] args) {
char c = 'A'; //字符常量值需要使用单引号囊括,并且内部只能有一个字符
System.out.println(c);
}
- 每个数字在计算机中都会对应一个字符,可以去认识一下
ASCII码
:
//英文字母`A`要展示出来,那就是一个字符的形式,
//而其对应的ASCII码值为65,所以说当char为65时,打印出来的结果就是大写的字母A了
public static void main(String[] args) {
char c = 65;
System.out.println(c);
}
- 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.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不能转换为布尔值