8种数据类型
数据类型 | 位数 | 默认值 | 取值范围 | 示例 |
---|---|---|---|---|
byte(位) | 8 | 0 | -2^7 - 2^7-1 | byte b = 1 |
short(短整型) | 16 | 0 | -2^15 - 2^15-1 | short s = 5 |
int(整型) | 32 | 0 | -2^31 - 2^31-1 | int i = 10 |
long(长整型) | 64 | 0 | -2^63 - 2^63-1 | long l = 10l |
float(单精度浮点型) | 32 | 0 | -2^31 - 2^31-1 | float f = 10.0f |
double(双精度浮点型) | 64 | 0 | -2^63 - 2^63-1 | double d = 10.0d |
char(字符) | 16 | 空 | 0 - 2^16-1 | char c = ‘c’ |
boolean(布尔值) | 8 | false | true、false | boolean f = false |
代码示例:
package com.ce.test;
class Test {
static byte b;
static short s;
static int i;
static long l;
static float f;
static double d;
static char c;
static boolean bo;
public static void main(String[] args) {
System.out.println("byte的大小:"+Byte.SIZE
+";默认值:"+b
+";数据范围:"+Byte.MIN_VALUE+" - "+Byte.MAX_VALUE);
System.out.println("short的大小:"+Short.SIZE
+";默认值:"+s
+";数据范围:"+Short.MIN_VALUE+" - "+Short.MAX_VALUE);
System.out.println("int的大小:"+Integer.SIZE
+";默认值:"+i
+";数据范围:"+Integer.MIN_VALUE+" - "+Integer.MAX_VALUE);
System.out.println("long的大小:"+Long.SIZE
+";默认值:"+l
+";数据范围:"+Long.MIN_VALUE+" - "+Long.MAX_VALUE);
System.out.println("float的大小:"+Float.SIZE
+";默认值:"+f
+";数据范围:"+Float.MIN_VALUE+" - "+Float.MAX_VALUE);
System.out.println("double的大小:"+Double.SIZE
+";默认值:"+d
+";数据范围:"+Double.MIN_VALUE+" - "+Double.MAX_VALUE);
System.out.println("char的大小:"+Character.SIZE
+";默认值:"+c
+";数据范围:"+Character.MIN_VALUE+" - "+Character.MAX_VALUE);
System.out.println("boolean的大小:"+Byte.SIZE
+";默认值:"+bo
+";数据范围:"+Byte.MIN_VALUE+" - "+Byte.MAX_VALUE);
}
}
此处为什么输出char的数据范围不是0 - 65535呢?
Java中的char类型由两个字节即十六位来表示,因为是无符号数,所以为2的16次方,数值范围就为:0 - 2^16-1;
类型转换:
char–> 自动转换:byte–>short–>int–>long–>float–>double 强制转换:①会损失精度,产生误差,小数点以后的数字全部舍弃。②容易超过取值范围。