JAVA基本数据类型转换

 

boolean类型不可以转换成其他的数据类型;

● ×××、字符型、浮点型的数据在混合运算中相互转换,转换时遵循如下规则:

■ 容量小的类型自动转换成容量大的数据类型;数据类型按容量大小排序如下:        

byteshort,charàintàlongàfloatàdouble

      要注意的是byteshort,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);

    打印结果:-128127

    分析:byte只有八位,只能表示-128127;计算机中负数的存储方式是补码。对负数的绝对值的二进制值取反,再加一,即为负数的二进制码。如:-1的绝对值1的二进制码为00000001,取反得到11111110,再加一为11111111-128的绝对值128的二进制码为10000000,取反得到01111111,再加一为10000000,正好是Byte的最大表示范围。而-129的绝对值129的二进制码为10000001,取反后得01111110,加一后得01111111,最后结果就是127