JAVA学习笔记(强制类型转换)

主要讨论的是非基本数据类型,即class类型之间的转换。我们知道,子类向父类的转换毫无疑问是可以顺利完成的(因为父类中的成员变量子类一定有)。但有时候为了使用多态性,需要将父类对象的句柄强制转换为子类的对象(强制造型),由于子类的成员可能在父类中没有,这时可能就会出现问题。

假设有以下两个类father和kid:

class father{
    int a;
    public father(int k) {    //构造函数
        this.a=k;
    }
}

class kid extends father{
    int b;
    public kid(int k) {       //构造函数
        super(k);
        b=2*k;
    }   
    public int getB() {
        return this.b;
    }
}

如果这样对引用f1做类型转换

public static void main(String[] args) {        
        father f1= new father(5);
        kid k=(kid)f1;
        System.out.println(k.getB());
    }

编译不会出问题而运行会抛出异常,提示father cannot be cast to kid

但修改一下主函数部分的类型转换方式:

public static void main(String[] args) {
        kid k1=new kid(10);
        father f1=(father)k1;
        kid k=(kid)f1;
        System.out.println(k.getB());
    }

输出结果

20

可见,变量f1本身就是子类的对象,由于一些原因暂时被转换为父类的对象引用了,但子类特有的数据部分并没有丢失,因此重新转换为子类对象时,可以顺利的访问子类特有的函数和成员变量。而前一个程序中,只是单纯想将父类对象转换为子类,显然是不行的。而这个问题编译时不会被发现。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值