Java 基本数据类型转换 自动类型转换 强制类型转换

首先放出结论:

1.小范围类型-->-->大范围类型:自动类型转换。

2.大范围类型-->-->小范围类型:

         1.若大范围类型的数超出小范围类型的值的范围: 报错,精度会有损失。

          2.若大范围类型的数没有超出小范围类型值范围:

                   1. 若小范围类型为byte short char,大范围为int:编译器自动补充强制类型转换。

                   2.其他情况:报错,精度会有损失,需按情况手动补上强制类型转换。

 

自动类型转换:


当数据类型不一样时,将会发生数据类型转换。
自动类型转换(隐式)
    1.特点:代码不需要进行特殊处理,自动完成。
    2.规则:数据范围从小到大。
强制类型转换(显式)

public class Demo01DataType {
    public static void main(String[] args) {
        System.out.println(1024); //这就是一一个整数,默认就是int类型
        System.out.println(3.14); //这就是一个浮点数,默认就是double类型
        //左边是long类型,右边是默认的int类型,左右不一样
        //一个等号代表赋值,将右侧的int常量,交给左侧的long变量进行存储
        // int --> long,符合了数据范围从小到大的要求
        //这一行代码发生了自动类型转换。
        long num1 = 100;    
        System.out.println(num1); // 100
        //左边是double类型,右边是float类型,左右不-样
        // float --> double, 符合从小到大的规则
        //也发生了自动类型转换
        double num2 = 2.5F;
        System.out.println(num2); // 2.5
        //左边是float类型,右边是long类型,左右不一样
        // long --> float, 范围是float更大-一些, 符合从小到大的规则
        //也发生了自动类型转换

强制类型转换:

强制类型转换
1.特点:代码需要进行特殊的格式处理,不能自动完成。
2.格式:范围小的类型  范围小的变量名= (范围小的类型)原本范围大的数据;
public class Demo02DataType {
    public static void main(String[] args) {
        //左边是int类型,右边是long类型,不一样
        // long --> int, 不是从小到大
        //不能发生自动类型转换!
        //格式:范围小的类型范围小的变量名= (范围小的类型)原本范围大的数据;
        int num = (int) 100L ;
        System.out.println(num) ;
    }
}

 

1. 强制类型转换一般不推荐使用,因为有可能发生精度损失、数据溢出。
2. byte/short/char这三种类型都可以发生数学运算,例如加法“+”.
3. byte/short/char这三种类型在运算的时候,都会被首先提升成为int类型,然后再计算。

public class Demo02DataType {
    public static void main(String[] args) {
        //左边是int类型,右边是long类型,不一样
        // long --> int, 不是从小到大
        //不能发生自动类型转换!
        //格式:范围小的类型范围小的变量名= (范围小的类型)原本范围大的数据;
        int num = (int) 100L ; .
        System.out.println(num);
        // long强制转换成为int类型
        int num2 = (int) 6000000000L ;
        System.out.println(num2); // 1705032704
        // double --> int, 强制类型转换
        int num3 = (int) 3.99; .
        System.out.println(num3); // 3,这并不是四舍五入,所有的小数位都会被舍弃掉
        char zifu1 = 'A'; //这是一个字符型变量,里面是大写字母A
        System.out.println(zifu1 + 1); // 66,也就是大写字母A被当做65进行处理
        //计算机的底层会用一个数字(二进制)来代表字符A,就是65
        //一旦char类型进行了数学运算,那么字符就会按照一定的规则翻译成为一个数字
        byte num4 = 40; //注意!右侧的数值大小不能超过左侧的类型范围
        byte num5 = 50;
        // byte + byte --> int + int --> int
        int result1 = num4 + num5;

 

补充:


对于byte/short/char三种类型来说,如果右侧赋值的数值没有超过范围,那么javac编译器将会自动隐含地补上一个(byte)( short)(char).
1. 如果没有超过左侧的范围,编译器补上强转。
2. 如果右侧超过了左侧范围,那么直接编译器报错。
public class Demo12Notice {
    public static void main(String[] args) {
        //右侧确实是一个int数字,但是没有超过左侧的范围,就是正确的。
        // int --> byte, 不是自动类型转换
        byte num1 = /*(byte)*/ 30; //右侧没有超过左侧的范围
        System.out.println(num1); // 30
        // byte num2 = 128; //右侧超过了左侧的范围
        // int --> char, 没有超过范围
        //编译器将会自动补上一个隐含的(char)
        char zifu = /*(char)*/ 65;
        System.out.println(zifu); // A
}

 


在给变量进行赋值的时候,如果右侧的表达式当中全都是常量,没有任何变量,那么编译器javac将会直接将若干个常量表达式计算得到结果。
short result = 5 + 8; //等号右边全都是常量,没有任何变量参与运算编译之后,得到的.class字节码文件当中相当于[直接就是] :short result = 13;右侧的常量结果数值,没有超过左侧范围,所以正确。
这称为“编译器的常量优化”。
但是注意:一旦表达式当中有变量参与,那么就不能进行这种优化了。

public class Demo13Notice {
    public static void main(String[] args) {
        short num1 = 10; //正确写法,右侧没有超过左侧的范围,
        short a = 5;
        short b = 8;
        // short + short --> int + int --> int
        // short result = a + b; //错误写法!左侧需要是int类型
        //右侧不用变量,而是采用常量,而且只有两个常量,没有别人
        short result = 5 + 8;
        System.out.println(result);
        short result2=5+a+8;//18 错误写法,左侧应为int类型
}

 

总结:

1.小范围类型-->-->大范围类型:自动类型转换。

2.大范围类型-->-->小范围类型:

                      1.若大范围类型的数超出小范围类型的值的范围: 报错,精度会有损失。

                      2.若大范围类型的数没有超出小范围类型值范围:

                                    1. 若小范围类型为byte short char:编译器自动补充强制类型转换。

                                    2.若小范围类型为 int:报错,精度会有损失。

  • 6
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值