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++全部都是父类的行为。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!