7:数据类型(掌握) 
        (1)Java是一种强类型语言,针对每种数据都提供了对应的数据类型。 
        (2)分类: 
                A:基本数据类型:4类8种 
                B:引用数据类型:类,接口,数组。 
        (3)基本数据类型 
                A:整数                        占用字节数           范围 
                        byte                        1        -128--127 
                        short                        2        -2^15--2^15-1 
                        int                         4        -2^31--2^31-1 
                        long                        8        -2^63--2^63-1 
                B:浮点数 
                        float                        4        -3.403E38--3.403E38 
                        double                        8        -1.798E308--1.798E308 
                C:字符 
                        char                        2 
                D:布尔 
                        boolean                        1 
                         
                注意: 
                        整数默认是int类型,浮点数默认是double。 
                         
                        长整数要加L或者l,建议用L。long j=100000000L 
                        单精度的浮点数要加F或者f,建议用F。float h=12.345F 
 
8:数据类型转换(掌握) 
        (1)boolean类型不参与转换 
        (2)默认转换 
                A:从小到大 
                B:byte,short,char -- int -- long -- float -- double 
                C:byte,short,char之间不相互转换,直接转成int类型参与运算。 
        (3)强制转换 
                A:从大到小 
                B:可能会有精度的损失,一般不建议这样使用。 
                C:格式: 
                        目标数据类型 变量名 = (目标数据类型) (被转换的数据); 
                例:byte a=3;   int b=4;    int c=a+b (默认转换) 
                byte c=(byte)(a+b)强制转换 
9:思考题和面试题: 
(1)下面两种方式有区别吗? 
float f1 = 12.345f; 
float f2 = (float)12.345; 
答:f1其实是通过一个double类型转换过来的。 
    而f2本身就是一个float类型。通常会使用第二种方法。 
(2)下面的程序有问题吗,如果有,在哪里呢? 
byte b1 = 3, b2 = 4 ,b; 
b = b1 + b2; 
b = 3 + 4; 
答:b=b1+b2有问题,因为变量相加,会首先看类型,最后把结果赋值时也会看类型。上面b1+b2的结果是int类型。所以会出错 
而b = 3 + 4是常量相加,首先会做加法,然后看结果是否在赋值的数据类型范围内,如果不是,就会报错。 
(3)下面的操作结果是什么呢? 
byte b = (byte)130; 
答;因为byte的范围是-128到127.而130不在这个范围内,所以会报错。我们可以使用强制类型转换。byte b=(byte)130; 
结果是多少呢? 
分析过程:我们要想知道结果是什么,就应该知道是如何进行计算的。而计算机中的数据的运算都是补码进行的。要得到补码,就要首先计算出数据的二进制。 
A:获取130这个数据的二进制 
00000000 00000000 00000000 100000010 
这是130的原码,因为是正数,所以也是它的反码,补码。 
B:因为byte只有一个字节,所以需要截取。 
100000010 
这个结果是截取成byte后的补码。 
C:已知补码,要求原码 
       符号位      数值位 
补码     1         0000010 
反码     1         0000001(向上借位减1) 
原码     1         1111110 
通过原码将二进制转换成十进制就是126,又因为首位是1,所以是-126. 
 
(4)字符参与运算 
字符与整数相加结果是整数 
是查找ASCII里面的值 
'a'                97 
'A'                65 
'0'                48 
                         
System.out.println('a');//a 
System.out.println('a' + 1);//97+1=98 
 
(5)字符串参与运算 
字符串数据和其他数据做+,结果是字符串类型,这里的+其实是字符串的连接符。 
                         
System.out.println("hello"+'a'+1);//helloa1 
System.out.println('a'+1+"hello");//98hello 
System.out.println("5+5="+5+5);//5+5=55 
System.out.println(5+5+"=5+5");//10=5+5 
 
 |   
        
 
    
    
    
     
 
 |