一、引言
变量就是申请内存来存储值。也就是说,当创建变量的时候,需要在内存中申请空间。
内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据。
通过定义不同类型的变量,可以在内存中储存整数、小数或者字符。
Java的两大数据类型:
- 内置数据类型(基本数据类型)
- 引用数据类型
二、内置数据类型
2.1整型数据类型
| 类型 | 占用存储空间 | 表数范围 | 默认值 |
|---|---|---|---|
| byte | 1字节(8位) | -2^7~2^7-1 (-128 ~127 ) | 0 |
| short | 2字节(16位) | -2^15~2^15-1(-32768 ~ 32767) | 0 |
| int | 4字节(32位) | -2^31~2^31-1(-2147483648 ~2147483647) | 0 |
| long | 8字节(64位) | -2^63~ 2^63-1(-9223372036854775808 ~9223372036854775807) | 0L |
2.2浮点型数据类型
| 类型 | 占用存储空间 | 表数范围 | 默认值 |
|---|---|---|---|
| float | 4字节(32位) | -3.403E38~ 3.403E38 | 0.0f |
| double | 8字节(64位) | -1.798E308~ 1.798E308 | 0.0d |
2.3字符型和布尔型
| 类型 | 表述范围 | 默认值 |
|---|---|---|
| boolean | true or false | false |
| char | \u0000(十进制等效值为0)~\uffff(即为65535) | \u0000 |
//Float和Double的最小值和最大值都是以科学记数法的形式输出的,结尾的"E+数字"表示E之前的数字要乘以10的多少次方。
三、实例
3.1代码
// byte
System.out.println("基本类型:byte 二进制位数:" + Byte.SIZE);
System.out.println("包装类:java.lang.Byte");
System.out.println("最小值:Byte.MIN_VALUE=" + Byte.MIN_VALUE);
System.out.println("最大值:Byte.MAX_VALUE=" + Byte.MAX_VALUE);
System.out.println();
// short
System.out.println("基本类型:short 二进制位数:" + Short.SIZE);
System.out.println("包装类:java.lang.Short");
System.out.println("最小值:Short.MIN_VALUE=" + Short.MIN_VALUE);
System.out.println("最大值:Short.MAX_VALUE=" + Short.MAX_VALUE);
System.out.println();
// int
System.out.println("基本类型:int 二进制位数:" + Integer.SIZE);
System.out.println("包装类:java.lang.Integer");
System.out.println("最小值:Integer.MIN_VALUE=" + Integer.MIN_VALUE);
System.out.println("最大值:Integer.MAX_VALUE=" + Integer.MAX_VALUE);
System.out.println();
// long
System.out.println("基本类型:long 二进制位数:" + Long.SIZE);
System.out.println("包装类:java.lang.Long");
System.out.println("最小值:Long.MIN_VALUE=" + Long.MIN_VALUE);
System.out.println("最大值:Long.MAX_VALUE=" + Long.MAX_VALUE);
System.out.println();
// float
System.out.println("基本类型:float 二进制位数:" + Float.SIZE);
System.out.println("包装类:java.lang.Float");
System.out.println("最小值:Float.MIN_VALUE=" + Float.MIN_VALUE);
System.out.println("最大值:Float.MAX_VALUE=" + Float.MAX_VALUE);
System.out.println();
// double
System.out.println("基本类型:double 二进制位数:" + Double.SIZE);
System.out.println("包装类:java.lang.Double");
System.out.println("最小值:Double.MIN_VALUE=" + Double.MIN_VALUE);
System.out.println("最大值:Double.MAX_VALUE=" + Double.MAX_VALUE);
System.out.println();
// char
System.out.println("基本类型:char 二进制位数:" + Character.SIZE);
System.out.println("包装类:java.lang.Character");
// 以数值形式而不是字符形式将Character.MIN_VALUE输出到控制台
System.out.println("最小值:Character.MIN_VALUE=" + (int) Character.MIN_VALUE);
// 以数值形式而不是字符形式将Character.MAX_VALUE输出到控制台
System.out.println("最大值:Character.MAX_VALUE=" + (int) Character.MAX_VALUE);
3.2运行结果
四、类型转换
4.1转换原则
1.类型转换主要发生在赋值、方法调用、算术运算三种情况下。
2.转换规则:从低位类型到高位类型自动转换;从高位类型到低位类型需要强制类型转换
- 布尔型和其它基本数据类型之间不能相互转换;
- byte型可以转换为short、int、long、float和double;
- short可转换为int、long、float和double;
- char可转换为int、long、float和double;
- int可转换为long、float和double;
- long可转换为float和double;
- float可转换为double;
基本数据类型由低到高顺序
char->short->int->long->float->double
4.2自动转换
如图:
4.3强制类型转换
如图:
4.4隐含强制类型转换
- 整数的默认类型是 int。
- 小数默认是 double 类型浮点型,在定义 float 类型时必须在数字后面跟上 F 或者 f。 如图:
五、二进制表示
byte、int、long、和short都可以用十进制、16进制以及8进制的方式来表示。
当使用字面量的时候,前缀 0 表示 8 进制,而前缀 0x 代表 16 进制, 如图:
六、转义字符
| 符号 | 含义 |
|---|---|
| \n | 换行 |
| \r | 回车 |
| \b | 退格 |
| \0 | 空字符 |
| \s | 空格 |
| \t | 制表符 |
| " | 双引号 |
| ' | 单引号 |
| \ | 反斜杠 |
七、总结
劝君莫惜金缕衣,劝君惜取少年时。
才疏学浅,拙文一篇欢迎雅正。