C++/java 继承类的多态详解及实例代码
C++/java继承类的多态详解
学过C++和Java的人都知道,他们二者由于都可以进行面向对象编程,而面向对象编程的三大特性就是封装、继承、多态,所有今天我们就来简单了解一下C++和Java在多态这方面的不同。
首先我们各看一个案例。
C++
//测试继承与多态
classAnimal{
public:
charname[128];
charbehavior[128];
voidoutPut(){
cout<<"Animal"<<endl;
}
voidoutPutAnimal(){
cout<<"Father"<<endl;
}
Animal(){
strcpy(name,"Animal");
strcpy(behavior,"Call");
}
};
classDog:publicAnimal{
public:
//子类定义一个和父类相同的属性
charname[128];
charsex;
//子类重写父类方法
voidoutPut(){
cout<<"Dog"<<endl;
}
voidoutPutDog(){
cout<<"Son"<<endl;
}
Dog(){
strcpy(name,"Dog");
sex='M';
}
};
以上两个类都很简单,我们来看一下其测试代码和结果。
/* 没有多态的情况下测试结果和Java相同 Dogdog; cout<<dog.name<<endl; cout<<dog.sex<<endl; cout<<dog.behavior<<endl; dog.outPut(); dog.outPutAnimal(); dog.outPutDog(); //可通过如下方式访问父类的行为 dog.Animal::outPut(); */ //多态的情况下: Animal*dog=newDog; cout<<dog->name<<endl; cout<<dog->behavior<<endl; dog->outPut(); dog->outPutAnimal(); //测试结果 Animal Call Animal Father
可以看出所有的表现都是父类的行为,无论是相同的属性还是重写的方法。在这里需要说明一下,如果子类隐藏了父类的成员函数,则父类中所有同名的成员函数(重载的函数)均被隐藏。如果想要访问父类中被隐藏的函数,需要通过父类名称来访问(dog.Animal::outPut();)。
在多态的情况下我们访问的都是父类的行为,那怎样才能访问到子类的函数呢?答案是通过定义虚函数来实现,这个我们后面的博文讲解。
现在我们在来看一下Java的表现。
Java
//父类
publicclassAnimal{
publicStringname="Animal";
publicStringbehavior="Call";
publicvoidoutPut(){
System.out.println("Animal");
}
publicvoidoutPutAnimal(){
System.out.println("Father");
}
}
//子类
publicclassDogextendsAnimal{
publicStringname="Dog";
publiccharsex='M';
publicvoidoutPut(){
System.out.println("Dog");
}
publicvoidoutPutDog(){
System.out.println("Son");
}
}
子类也是定义了一个和父类相同的属性,同时也重写了父类的一个方法,我们看一下其测试方法和测试结果。
publicstaticvoidmain(String[]args){
Animaldog=newDog();
System.out.println(dog.name);
System.out.println(dog.behavior);
dog.outPut();
dog.outPutAnimal();
}
//测试结果
Animal//父类行为
Call
Dog//表现的是子类的行为
Father
从这里可以看出,Java和C++还是有区别的,Java的属性表现的是父类的行为,但是重写的方法却是子类的行为,而C++全部都是父类的行为。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!