内置数据类型
Java 语言提供了八种基本类型。六种数字类型(四种整数、两种浮点类型)、一种字符类型和一种布尔类型。
字节:
byte 数据类型是8位、有符号的,以二进制补码表示的整数;
最小值是 -128(-2^7);
最大值是 127(2^7-1);
默认值是 0;
byte 类型用在大型数组中节约空间,主要代替整数,因为 byte 变量占用的空间只有 int 类型的四分之一;
例子:byte a = 100,byte b = -50。
短的:
short 数据类型是 16 位、有符号的以二进制补码表示的整数
最小值是 -32768(-2^15);
最大值是 32767(2^15 - 1);
Short 数据类型也可以像 byte 那样节省空间。一个short变量是int型变量所占空间的二分之一;
默认值是 0;
例子:short s = 1000,short r = -20000。
整数:
int 数据类型是32位、有符号的以二进制补码表示的整数;
最小值是 -2,147,483,648(-2^31);
最大值是 2,147,483,647(2^31 - 1);
一般地整型变量默认为 int 类型;
默认值是 0 ;
例子:int a = 100000, int b = -200000。
长的:
long 数据类型是 64 位、有符号的以二进制补码表示的整数;
最小值是 -9,223,372,036,854,775,808(-2^63);
最大值是 9,223,372,036,854,775,807(2^63 -1);
这种类型主要使用在需要比较大整数的系统上;
默认值是 0L;
例子: long a = 100000L,long b = -200000L。
"L"理论上不分大小写,但是若写成"l"容易与数字"1"混淆,不容易分辩。所以最好大写。
漂浮:
float 数据类型是单精度、32位、符合IEEE 754标准的浮点数;
float 在储存大型浮点数组的时候可节省内存空间;
默认值是 0.0f;
浮点数不能用来表示精确的值,如货币;
例子:float f1 = 234.5f。
双倍的:
double 数据类型是双精度、64 位、符合 IEEE 754 标准的浮点数;
浮点数的默认类型为 double 类型;
double类型同样不能表示精确的值,如货币;
默认值是 0.0d;
例子:
double d1 = 7D ;
double d2 = 7.;
double d3 = 8.0;
double d4 = 8.D;
double d5 = 12.9867;
7 是一个 int 字面量,而 7D,7. 和 8.0 是 double 字面量。
布尔值:
boolean数据类型表示一位的信息;
只有两个取值:true 和 false;
这种类型只作为一种标志来记录 true/false 情况;
默认值是 false;
例子:boolean one = true。
字符:
char 类型是一个单一的 16 位 Unicode 字符;
最小值是 \u0000(十进制等效值为 0);
最大值是 \uffff(即为 65535);
char 数据类型可以储存任何字符;
例子:char letter = ‘A’;。
包装类型
Java 中的八个包装类是:Byte、Short、Integer、Long、Float、Double、Character 和 Boolean。它们的使用方式都是一样的,都可以实现原生数据类型和包装类型之间的双向转换。
一个类包含若干属性和方法,用来完成某个行为。但是最基本类型不是对象,所以需要借助相应的包装类来实现相关的操作。
自动装箱和自动拆箱
包装类提供的相应方法使得它们之间可以互相转换,自动装箱和自动拆箱的原理。例如:
//构造方法包装类与基本数据类型转换
int n = 10;
Integer in = new Integer(100);
//将int类型转换为Integer类型
Integer in1 = new Integer(n);
//成员方法转化
//将Integer类型的对象转换为int类型
int m = in.intValue();
主要就是以下的两个方法valueOf和xxxVlue方法 就是包装类和基本数据类型的转化方法:
intValue方法将对象类型转为基本数据类型(在其他的包装类中都有相应的xxxValue方法的转换)
//包装类转基本数据类型
Integer i = new Integer(12);
int i1 = i.intValue();
System.out.println(i.getClass().getName()); //java.lang.Integer
System.out.println(i1); //12
//基本数据类型转包装类
Integer i = Integer.valueOf(12);
System.out.println(i.getClass().getName()); //java.lang.Integer
//还有一个比较重要的静态方法parseXXX将字符串解析为某个基本类型
double s = Double.parseDouble("123.13");
int a = Integer.parseInt("123")
自动装箱是指Java自动将原始类型值转换为对应的对象。例如,将 int 变量转换为 Integer 对象称为装箱。相反,将 Integer 对象转换为 int 类型值称为拆箱。装箱和拆箱是自动的、非人工的转换,所以称为自动装箱和拆箱。自动装箱时,编译器调用 valueOf 将原始类型值转换为对象。同时,在自动拆箱时,编译器会通过调用intValue()、doubleValue()等方法将对象转换为原始类型值。
数据类型转换
运算时,可以将整数、实数(常量)、字符数据混合运算。不同类型的数据首先转换为同一类型,然后进行操作。
数据类型转换必须满足以下规则:
-
无法对布尔类型执行类型转换。
-
对象类型不能转换为不相关类的对象。
-
将大容量类型转换为小容量类型时必须使用铸造。
-
转换过程中可能会出现溢出或精度损失,例如:
int i =128;
byte b = (byte)i;
因为byte类型是8位,最大值为127,所以当int转换为byte类型时,值128会导致溢出。
- 从浮点数到整数的转换是通过丢弃小数而不是四舍五入来获得的,例如:
(int)23.7 == 23;
(int)-45.89f == -45
自动类型转换
转换前的数据类型的位数必须小于转换后的数据类型的位数。例如:如果short数据类型的位数为16位,则可以自动转换为32位的int类型。同样,float数据类型的位数为32位,它可以自动转换为64位double类型。
public class App{
public static void main(String[] args){
char c1='a';//定义一个char类型
int i1 = c1;//char自动类型转换为int
System.out.println("char自动类型转换为int后的值等于"+i1);
char c2 = 'A';//定义一个char类型
int i2 = c2+1;//char 类型和 int 类型计算
System.out.println("char类型和int计算后的值等于"+i2);
}
}
char自动类型转换为int后的值等于97
char类型和int计算后的值等于66
投掷
-
条件是转换后的数据类型必须兼容。
-
格式:
(type)value type
是要强制类型转换后的数据类型 ,使用(转换类型)强制转换。
public class App{
public static void main(String[] args){
int i1 = 123;
byte b = (byte)i1;//强制类型转换为byte
System.out.println("int强制类型转换为byte后的值等于"+b);
}
}