在多态中成员函数的特点:
在编译时期:参阅引用型变量所属的类中是否有调用的方法。如果有,编译通过,如果没有,编译失败。
在运行时期:参阅对象所属的类中是否有调用的方法。
简单总结就是:成员函数在多态调用时,编译看左边,运行看右边。
class Fu
{
void method1()
{
System.out.println("fu method_1");
}
void method2()
{
System.out.println("fu method_2");
}
}
class Zi extends Fu{
{
void method1()
{
System.out.println("zi method_1");
}
void method3()
{
System.out.println("zi method_3");
}
}
public class Duotai {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Fu f = new Zi();
f.method1();
f.method2();
f.method3();//此行编译不能通过
}
}
Duotai.class运行后的结果是:zi method_1 //参阅 Zi 对象所属的类中是否有调用的方法。
fu method_2//从父类继承的方法。
在多态中成员变量的特点:
无论编译和运行,都参考左边(引用型变量所属的类)。
在多态中静态成员函数的特点:
无论编译和运行,都参考左边(引用型变量所属的类)。
class Fu
{
int num = 10;
void method1()
{
System.out.println("fu method_1");
}
void method2()
{
System.out.println("fu method_2");
}
static void methed4()
{
System.out.println("fu method_4");
}
}
class Zi extends Fu{
{
int num = 20;
void method1()
{
System.out.println("zi method_1");
}
void method3()
{
System.out.println("zi method_3");
}
static void methed4()
{
System.out.println("zi method_4");
}
}
public class Duotai {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Fu f = new Zi();
System.out.println(f.num);
f.method4();
Zi z = new Zi();
System.out.println(z.num);
z.method4();
}
}
以上代码的运行结果是:10 // 引用型变量 f 所属的类是父类,所以结果是父类中的num = 10
fu method_4 // 引用型所述的类
20 // 引用型变量 z 所属的类是子类,所以结果还是父类中的num = 20
zi method_4 // 引用型所述的类