对象上转型验证


父类:
public class F {
    
    private String name = "F";

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
    
    public void printff(){
        System.out.println("F.printff: name:"+this.name+" getName:"+this.getName()+"  class:"+this.getClass()+"  this:"+this);
    }

}


子类:

public class S extends F {
    
    private String name = "S";

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void printff() {
        super.printff();
        System.out.println("S.printff: name:"+this.name+" getName:"+this.getName()+"  class:"+this.getClass()+"  this:"+this);
    }
    
    public void printfff(){
        System.out.println("S.printfff: name:"+this.name+"  class:"+this.getClass()+"  this:"+this+" super.name:"+super.getName());
    }
}



主函数:

public class M {

    public static void main(String[] args) {
        S s = new S();
        F f = s;
        f.printff();
//        f.printfff();  //无此方法
//        s.printfff();

    }

}



结果输出:

F.printff: name:F getName:S  class:class FandS.S  this:FandS.S@41a4555e
S.printff: name:S getName:S  class:class FandS.S  this:FandS.S@41a4555e


结论:

1、this指的是实例化对象,即便上转为父类型的引用。(只改变了引用类型,对象的内存其实未发生变化,只是在父类缺省的方法无法调用,即f.printfff无法调用。)

2、在使用super方法时,被重写的方法被覆盖,即父类的getName()方法被重写了,不会存在2个getName方法。

属性则不同,将存在父类属性与子类属性,可以用不同的方式访问得到,即对象上转时,保存了两者的属性。



引用http://niewj.iteye.com/blog/1216900:

子类的实例化主要分为两个步骤:

<1>.类相关静态内容初始化;

*先父类再子类:

  1.父类的static属性;

  2.父类的static块;

  3.子类的static属性;

  4.子类的static块;

<2>.类的实例内容初始化;

*调用构造子:先父类后子类:构造子调用之前先实例化实例字段和块

  5.父类的普通属性;

  6.父类的普通块;

  7.父类的构造子;

  8.子类的普通属性;

  9.子类的普通块;

  10.子类的构造子;



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值