java中的类型转换分为自动类型转换(隐式)和强制类型转换(显式)。
首先介绍一下java中需要我们注意的几种类型的常量:
1.1十六进制整型常量
以十六进制表示时,需以0x或0X开头,如0x10,0Xff.
0~9 ----->A~F
1.2八进制整型常量
八进制必须以0开头,如0123,034.
1.3长整型
长整型必须以L做结尾,如8L,89L,
1.4浮点数常量
由于小数常量的默认类型是double型,所以float类型的后面一定要加f(F)。同样带小数的变量默认为double类型。
float f=3.14f; //必须声明f
1.5字符常量
字符型常量需用两个单引号括起来(注意字符串常量是用两个双引号括起来)。Java中的字符占两个字节。
一些常用的转义字符。
①\r表示接受键盘输入,相当于按下了回车键;
②\n表示换行;
③\t表示制表符,相当于Table键;
④\b表示退格键,相当于Back Space键;
⑤\’表示单引号;
⑥\’’表示双引号;
⑦\\表示一个斜杠\。
2. 简单数据类型之间的转换
2.1 自动类型转换(隐式)
当一个较“小”数据与一个较“大”的数据一起运算时,系统将自动将“小”数据转换成“大”数据,再进行运算。
这些类型由“小”到“大”分别为 (byte,short,char)--int--long--float—double。这里我们所说的“大”与“小”,并不是指占用字节的多少,而是指表示值的范围的大小。
注意:
1)低级类型为char型,向高级类型(整型)转换时,会转换为对应ASCII码值(所有字符本身都是数字)。
a=97; A = 65;
char a = 'a';
int num = a;
System.out.println("num:"+num); //97
2) 对于byte,short,char三种类型而言,他们是平级的,因此不能相互自动转换,可以使用强制类型转换。之所以要给byte,short,char三个类型加上括号,是因为,当它们参与运算时首先会被提升为int类型,也就说明他们之间不会发生隐式类型转换。请看下面这段代码:
public static void main(String[] args)
{
byte a;
short b;
char c;
int d;
long e;
// a = a + a; 编译报错,计算时byte会提升为int类型,
a = 'A'; //正确,A=65,在byte范围内
a = 12 ;
/*12这个字面量在java中是int类型,但是a是byte类型,为什么不报错呢?
因为,编译器知道12在byte范围内,所以自动转为(short)12,
但如果赋值的是a = 200,那就错误了,因为编译器知道200是超出byte范围的
(在编译的时候,编译器只知道常量的值,知道它是否超出范围,编译器不知道变量的值,
所以无法判断一个变量是否超出范围,因为变量的值是在运行的时候确定的)*/
// a = Byte.MAX_VALUE +1 ; 编译报错
// b = Short.MAX_VALUE + 1; 编译报错
// c = Character.MAX_VALUE + 1 ; 编译报错
//上述三行报错原因是因为,byte,short,char三个类型参与计算时首先会提升为int类型,
// 但在C语言当中(char和short类型)参与计算时不会被提升,所以在C语言中值为 -1
d = Integer.MAX_VALUE + 1;
e = Long.MAX_VALUE + 1;
System.out.println("d:"+d);
System.out.println("e:"+e);
/* d:-2147483648
e:-9223372036854775808
因为int和long类型不存在提升,但是内存溢出了
*/
}
2.2 强制类型转换(显式)
将“大”数据转换为“小”数据时,你可以使用强制类型转换。即你必须采用下面这种语句格式:
变量类型 变量名 = (强转类型)值;
如: short a = (short) 3;
注意:
1.不能对布尔值进行强制转换
2.不能把对象类型转换为不相干的类型
3.在把高容量转换到低容量的时候,强制转换。
4.转换的时候可能存在内存溢出或者精度问题。
5.浮点数不能进行比较,若进行精确运算使用BigDecimal
6.有多种数据类型进行混合运算时,JAVA会先将所有数据类型转换陈表示范围大的那一种数据类型在进行运算
//操作比较大的数时,注意内存溢出问题
//JDK7新特性,数字之间可以用下划线分割
int money = 10_0000_0000;
int year = 20;
int total = money*year;
long total2 = money*year;
long total3 = money*((long)year);
System.out.println(total);//-1474836480 计算的时候内存溢出
System.out.println(total2);//-1474836480 默认是int,转换之前已经存在问题了。
System.out.println(total3);//20000000000 先把一个数转换为long