Java语言中的数据类型转换分两种:
自动类型转换:编辑器自动完成类型转换,不需要在程序中编写代码。
强制类型转换:强制编译器进行类型转换,必须在程序中编写代码。
自动类型转换:
自动类型转换,也称隐式类型转换,是指不需要手写代码,由系统自动完成的类型转换。由于实际开发中这样的类型转换很多,所以Java语言在设计时,没有为该操作设计语法,而是由JVM自动完成。
转换规则:从存储范围小的类型到存储范围大的类型。
具体规则为:byte->short(char)->int->long->float->double
也就是说byte类型的变量可以自动转换为short类型。举例说明:
byte b=10;
short sh=b;
这里在赋值时,JVM首先将b的值转换为short类型,然后再赋值给sh。
在类型转换时可以跳跃。举例说明:
byte b1=100;
int n=b1;
注意问题:在整数之间进行类型转换时,数值不发生改变,而将整数类型,特别是比较大的整数类型转换成小数类型时,由于存储方式不同,有可能存在数据精度的损失。举例说明:
char c='1';
int a = c;
输出a为49,c是为1的ASCII码存在内存中,转换则需要将c-48。同理,int 转成char 则需要a+48。
强制类型转换:
强制类型转换,也称显式类型转换,是指必须书写代码才能完成的类型转换。该类型转换很可能存在精度的损失,所以必须书写相应的代码,并且能够忍受该种损失时才进行类型的转换。
具体规则为:double->float->long->int->short(char)->byte
语法格式为:(转换到的类型)需要转换的值
示例代码:
double d=3.10;
int n=(int)d;
这里将double类型的变量d强制转成int类型,然后赋值给变量n。需要说明的是小数强制转换为整数,采用的是去“1”法,也就是无条件的舍弃小数点的所有数字,则以上转换出的结果是3。整数强制转换为整数时取数字的低位,例如int类型的变量转换为byte类型时,则只取int类型的低8位(也就是最后一个字节)的值。
举例代码:
int n=123;
byte b=(byte)n;
int m=1234;
byte b1=(byte)m;
而b的值还是123,而b1的值为-46。b1的计算方法如下:m的值转换为二进制10011010010,取该数字的低8位的值作为b1的值,而b1的二进制时11010010,按照机器输的规定,最高位时符号位,1代表负数,在计算机中复数存储是补码,则负数的原码是10101110,该值就是十进制的-46。
注意问题:强制类型转换通常都会有存储精度的损失,所以使用时需要谨慎。举例说明(int 转成char)
int a=40;
char c=(char) a;
输出:(
因为字符(的ASCII编码为40,所以整形int强制类型转换为字符型,会得到字符'('
//或者先转成字符串,再转成char
int a=4;
String str=String.valueOf(a);
char[] array=str.toCharArray();
for(int I=0;i<array.length;i++){
System.out.println(array[i]);
}
//再或者第三种方法
3.加上48,因为ASCII编码48-57为字符‘0’-‘9’的编码。