JAVA根本数据类型转换

JAVA基本数据类型转换
● boolean类型不可以转换成其他的数据类型;
● 整形、字符型、浮点型的数据在混合运算中相互转换,转换时遵循如下规则:
    ■ 容量小的类型自动转换成容量大的数据类型;数据类型按容量大小排序如下:         byte,short,char-->int->long-->float-->double
        要注意的是byte,short,char之间不会相互转换,他们三者在计算时首先转换 为int类型。byte的取值范围是-128~127
    ■  容量大的数据类型转换为容量小的数据类型时,要加上强制转换符,但可能造成精
度降低或者溢出;使用时候要格外注意。
    ■  有多种类型的数据混合运算时,系统首先自动地将所有类型转换成容量最大的那个
数据类型,然后再进行计算。
实数常量(如:1.2)默认为double。(故:float f = 22.2;是错误的)
整数类型(如:123)默认为int。
可以直接把一个int类型的数赋值给一个byte,short,char类型的变量,但是不能超过其对应的范围(直接截取最后的一个字节)
● 要理解容量大的数强制转换成容量小的数的实质是截取后面的字节(如:long类型转换成int类型的时候,是直接取long类型中4个字节),但是double转换成float类型,由于double中存在小数点的情况,因此直接加强制转换时转换不过来的(infinity)。
● long类型8个字节,int类型4个字节,short类型2个字节,byte类型1个字节。
Float类型4个字节,double类型8个字节。
l  典型问题:
(1)  double d = 1e200;float f=(float)d;//打印f显示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