Fork me on GitHub

 1. boolean不参加转换

 2.显示转换 (强制类型转换) 

             A:从大到小
             B:可能会有精度的损失,一般不建议这样使用。
             C:格式:
                       目标数据类型 变量名 = (目标数据类型) (被转换的数据);

3.隐式转换:

             A:从小到大
             B:byte,short,char -- int -- long -- float -- double
             C:byte,short,char之间不相互转换,直接转成int类型参与运算。

eg:

A:下面两种方式有区别吗?
              float f1 = 12.345f;//本身就是浮点数 不存在转换
              float f2 = (float)12.345;//存在转换:将double转换为float;大转小须强转

     区别:存在强转
B:下面的程序有问题吗,如果有,在哪里呢?
              byte b1 = 3;
              byte b2 = 4;
              byte b3 = b1 + b2;//byte=byte+byte
              byte b4 = 3 + 4;//byte=int+int;大转小存在强转   转成int-->byte
C:下面的操作结果是什么呢?
              byte b = (byte)130;//将int类型强转为byte
D:字符参与运算
            是查找ASCII里面的值
                'a' 97
                'A' 65
                '0' 48
           System.out.println('a');
           System.out.println('a' + 1);
E:字符串参与运算
           这里其实是字符串的连接
         System.out.println("hello"+'a'+1);    

         string+char+int------>string+string+string

           resoult:"helloa1"//字符串相加
         System.out.println('a'+1+"hello");

           char+int+hello-------->int+int+string----->('a'=97)+1+"hello"

             resoult:"98hello"//‘a’表示的的ASCII值就是97 +1+“hello”
         System.out.println("5+5="+5+5);

           string+int+int------>string+string+string

           resoult:5+5=55 
         System.out.println(5+5+"=5+5");

          int+int+string-------->int+int+string

           resoult:10=5+5

规律:输出格式 跟第一个“+”数据格式有关

其他问题:

1:在定义Long或者Float类型变量的时候,要加L或者f。
            整数默认是int类型,浮点数默认是double。
            byte,short在定义的时候,他们接收的其实是一个int类型的值。
            这个是自己做了一个数据检测的,如果不再它们的范围内,就报错。
2:byte值的问题
                  byte b1 = 127;
                  byte b2 = (byte)128; //-128
                  byte b3 = (byte)129; //-127
                  byte b4 = (byte)130; //-126
    byte的范围:-128 ~ 127
                  128:10000000
                 -128:10000000 (这里的1即是符号位,也是数值位)
3:数据类型转换之默认转换
             byte,short,char -- int -- long -- float -- double
                  long: 8个字节
                  float:4个字节
        A:它们底层的存储结构不同。
        B:float表示的数据范围比long的范围要大
              long:2^63-1
              float:3.4*10^38 > 2*10^38 > 2*8^38 = 2*2^3^38 = 2*2^114 > 2^63-1

4:Java语言中的字符char可以存储一个中文汉字吗?为什么呢?
              可以。因为java语言中的字符占用两个字节。
               Java语言采用的是Unicode编码。

posted on 2017-01-03 17:56  TopTime  阅读(172)  评论(0编辑  收藏  举报