JAVA基本数据类型转换
● boolean类型不可以转换成其他的数据类型;
● ×××、字符型、浮点型的数据在混合运算中相互转换,转换时遵循如下规则:
■ 容量小的类型自动转换成容量大的数据类型;数据类型按容量大小排序如下:
byte,short,charàintàlongàfloatàdouble
要注意的是byte,short,char之间不会相互转换,他们三者在计算时首先转换为int类型。byte的取值范围是-128~127
n 容量大的数据类型转换为容量小的数据类型时,要加上强制转换符,但可能造成精
度降低或者溢出;使用时候要格外注意。
n 有多种类型的数据混合运算时,系统首先自动地将所有类型转换成容量最大的那个
数据类型,然后再进行计算。
● 实数常量(如:1.2)默认为double。(故:float f = 22.2;是错误的)
● 整数类型(如:123)默认为int。
● 可以直接把一个int类型的数赋值给一个byte,short,char类型的变量,但是不能超过其对应的范围(直接截取最后的一个字节)。
● 要理解容量大的数强制转换成容量小的数的实质是截取后面的字节(如:int类型转换成double类型的时候,是直接取int类型中4个字节的最后一个字节),但是double转换成float类型,由于double中存在小数点的情况,因此直接加强制转换时转换不过来的(infinity)。
● long类型8个字节,int类型4个字节,short类型2个字节,byte类型1个字节。
float类型4个字节,double类型8个字节。
l 典型问题:
(1) double d = 1e200;//打印显示Infinity;
(2) float f = 11.1//错误;默认为double类型,应该修改为float f = 11.1f;
(3)public class TestDataKind {
public static void main(String[] args) {
byte b = 44;
char c = 'b';
short s = 1024;
int i = 40000;
long l = 12463l;
float f = 35.67f;
double d = 3.1234d;
/*
* (f * b)时,b自动提升为float类型 (l*f)时,l自动提升为float类型 (i/c)
*时,c自动提升为int类型
* (d*s)时,s自动提升为double类型 再相加时,中间结果都变为了double类型。
* 这里result只能声明为double类型,result声明为其他类型会出错,除非进行
*强制类型转换
*/
double result = (f * b) + (l * f) + (i / c) - (d * s);
System.out.print((f * b) + " + " + (l * f) + " + " + (i /
c) + " - " + (d * s));
System.out.println(" = " + result);
}
}
(4) byte b1 = (byte)128;
byte b2 =(byte)-129;
System.out.println(b1);
System.out.println(b2);
打印结果:-128和127
分析:byte只有八位,只能表示-128—127;计算机中负数的存储方式是补码。对负数的绝对值的二进制值取反,再加一,即为负数的二进制码。如:-1的绝对值1的二进制码为00000001,取反得到11111110,再加一为11111111。-128的绝对值128的二进制码为10000000,取反得到01111111,再加一为10000000,正好是Byte的最大表示范围。而-129的绝对值129的二进制码为10000001,取反后得01111110,加一后得01111111,最后结果就是127