类型转换(隐式+强制)

一、隐式转换介绍

把一个取值范围小的数值或者变量,赋值给另一个取值范围大的变量

public class Test {
    public static void main(String[] args) {
        int a = 10;
        double b = a;
        System.out.println(b);//10.0
    }
}
问题: loat占用4个字节,为什么放在了Long(8个字节)的后面
解释: 虽然fLoat占用4个字节,但是 取值范围要比8个字节的long 更大.(小数的二进制存储形式, 更加节省内存)

运算过程中的隐式转换

  • 取值范围小的数据和取值范围大的数据进行运算,小的会先提升为大的之后,再进行运算

public class Test {
    public static void main(String[] args) {
        int a = 10;
        double b = 12.3;
        double c = a + b;//22.3
    }
}
  • byte short char 三种数据在运算的时候,都会提升为int,然后再进行运算

二、强制转换介绍

把一个取值范围大的数值或者变量,赋值给另一个取值范围小的变量不允许直接赋值,需要加入强制转换

格式:目标数据类型 变量名 = (目标数据类型) 被强转的数据

public class Test {
    public static void main(String[] args) {
        double a = 12.3;
        int b = (int) a;

        System.out.println(b);//12
    }
}
注意:强制转换 有可能会出现精度损失(int转byte时有可能不会)

三、原码、反码和补码

十进制 110
二进制 0b110
八进制 0110(今后编写数值尽量不要以0开头)
十六进制 0x110

正数的原反补码一样

四、类型转换面试题

下列代码是否存在错误, 如果有, 请指出说明,并改正。
byte b1 = 3;
byte b2 = 4;
byte b3 = b1 + b2;
错误原因: b1和b2是两个byte类型,在运算的时候,会提升为int类型提升之后,就是两个int在运算了,运算的结果还是int.将int类型的结果,赋值给byte类型的变量,属于大给小,不能直接给。
解决办法
byte b1 = 3;
byte b2 = 4;
byte b3 = (byte)(b1 + b2);

System.out.printin(b3);
升级
byte b = 3 + 4;

这个代码是正确的。

Java存在常最优化机制 : 在编译的时候 (javac) 就会将3和4这两个字面量进行运算.
产生的字节码文件 : byte b = 7;

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值