当俩个类之间存在继承关系的同时,可以利用父类的引用指向子类的对象
语法:父类引用名 =new 子类类型();
//引用名字只是类似一个地址链接,实际的类型大小是new申请的类
== 左边是编译类型,右边申请具有空间的是实际运行类型==
但是属性是编译后就决定了,跟运行类型无关,运行类型关联的的是逻辑运算
父类代码:
public void ca(){ System.out.print("huhuang"); } public void action(){ for(int i=1;i<=5;i++) System.out.println("repeat move of camera"); } public void gudd(int a,int b) { int x=a; Scanner scan =new Scanner(System.in); b=scan.nextInt(); for(int x1=x;x<=b;b++) for(int j=0;j<=x;j++) { System.out.print("书橱浑身是汗**************"); } }
子类代码: public int sonmoth(int ad) { int x=ad; return x; } public void action() { System.out.println("我是子类部分"); } public void bb() { System.out.println("人生是如滴水成沙,杂乱无章而没得别出一格"); }
测试:可以发现,调用时,方法的引用是从编译类型里面寻找
而当子类出现与父类同名的方法时,运行结果是子类方法*实际在内存中运行的是实际运行类型,如果没有才是寻找编译类型
*
值得注意的事情,转型的调用也遵守权限修饰符(public pretend default private)
接下提一下向下转型*把父类的引强制转换回子类,使其强转为编译类型,当然运行类型依旧是子类,也就是说子类同时是编译类型*
System.out.println("演示向下转型"); System.out.println("====================="); System.out.println("====================="); son son=(son)f1; son.indispensable();//通过向下转型(强制转换)父类的引用,来达到直接调用子类的方法 //本来向上转型过后,无法调用子类独有的方法,只能调用父类(编译)类的方法,但是可以通过强制转换来使其调用子类的方法; } ```**向下转型和向上转型不同, 向下转型是:父类引用子类用父类的方式引用子类,左边为编译型,右边new的为运行型 **父类引用名 =new 子类类型()** **而向下转型是为将通过向下转型 1. List item (强制转换)父类的引用,来达到直接调用子类的方法** 向上转型只需要有继承关系即可,但是向下转型需要该子类原本就是父类所引用的类型
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)