多态的实现主要分为静态多态和动态多态,静态多态主要是重载,在编译的时候就已经确定;动态多态是用虚函数机制实现的,在运行期间动态绑定。举个例子:一个父类类型的指针指向一个子类对象时候,使用父类的指针去调用子类中重写了的父类中的虚函数的时候,会调用子类重写过后的函数,在父类中声明为加了virtual关键字的函数,在子类中重写时候不需要加virtual也是虚函数。
相同的方法不同的实现,体现出多态,通俗理解为:“多种状态”,一龙生九子,九子不同
多态分为三种:
1: 方法多态
2: 类多态
3:接口多态
重写:是覆盖
重载:是方法名字相同,参数列表不同,参数 类型不同
接口是算多态的
举例吧:
JbuttonaddActionListener(new ActionListener(){
public void actionPerformed(){
}
});
这就是属于 接口多态,实现
方法多态:
有点类似于重载
类多态:
就继承关系
多态(Polymorphism)按字面的意思就是“多种状态”。在面向对象语言中,接口的多种不同的实现方式即为多态。引用Charlie Calverts对多态的描述——多态性是允许你将父对象设置成为一个或更多的他的子对象相等的技术,赋值之后,
父对象就可以根据当前赋值给它的子对象的特性以不同的方式运作(摘自“Delphi4 编程技术内幕”)。简单的说,就是一句话:允许将子类类型的指针赋值给父类类型的指针。多态性在Object Pascal和C++中都是通过虚函数实现的。
多态指同一个实体同时具有多种形式。它是面向对象程序设计(OOP)的一个重要特征。如果一个语言只支持类而不支持多态,只能说明它是基于对象的,而不是面向对象的。C++中的多态性具体体现在运行和编译两个方面。
运行时多态是动态多态,其具体引用的对象在运行时才能确定。编译时多态是静态多态,在编译时就可以确定对象使用的形式。
多态:同一 *** 作作用于不同的对象,可以有不同的解释,产生不同的执行结果。在运行时,可以通过指向基类的指针,来调用实现派生类中的方法。
C++中,实现多态有以下方法:虚函数,抽象类,覆盖,模板(重载和多态无关)。
OC中的多态:不同对象对同一消息的不同响应子类可以重写父类的方法
多态就是允许方法重名 参数或返回值可以是父类型传入或返回。
扩展资料:
把不同的子类对象都当作父类来看,可以屏蔽不同子类对象之间的差异,写出通用的代码,做出通用的编程,以适应需求的不断变化。
赋值之后,父类型的引用就可以根据当前赋值给它的子对象的特性以不同的方式运作。也就是说,父亲的行为像儿子,而不是儿子的行为像父亲。
比如从某个基类派生出多个子类,其基类有一个虚方法Tdoit,然后其子类也有这个方法,但行为不同,然后这些子类对象中的任何一个可以赋给其基类对象的引用,或者说将子对象地址赋给基类指针,这样其基类的对象就可以执行不同的 *** 作了。
实际上你是在通过其基类的引用来访问其子类对象的,你要做的就是一个赋值 *** 作。
使用继承性的结果就是当创建了一个类的家族,在认识这个类的家族时,就是把子类的对象当作基类的对象,这种认识又叫作upcasting(向上转型)。这样认识的重要性在于:我们可以只针对基类写出一段程序,但它可以适应于这个类的家族,
因为编译器会自动找出合适的对象来执行 *** 作。这种现象又称为多态性。而实现多态性的手段又叫称动态绑定(dynamic binding)。
参考资料:
什么是多态?
可以这么回答:
父类引用
引用子类对象
父类和子类有同名的覆盖方法
通过父类引用调用这个重写的方法的时候。多数的话就可以称为多态,单数可以说运行时绑定。
使用多态有什么好处?
类调用者对类的使用成本进一步降低
封装是让类的调用者不需要知道类的实现细节,多态能让类的调用者连这个类的类型是什么都不必知道,只需要知道这个对象具有某个方法即可。因此,多态可以理解成是封装的更进一步,让类调用者对类的使用成本进一步降低。
能够降低代码的“圈复杂度”,避免使用大量的if-else
多态在代码中的体现:
输出结果:
猫吃鱼
猫吃鱼(因为描述的是真正的是一只猫)
拓展:
多态性:同一 *** 作作用于不同的对象,可以用不同的解释,产生不同的执行结果,这就是多态性。
多态性通过派生类覆写基类中的虚函数的方法来实现。
多态性分为两种,一种是编译时的多态性,一种是运行时的多态性。
编译时的多态性:编译时多态是通过重载来实现的。对于非虚的成员来说,系统在编译时,根据传递的参数,返回的类型等信息决定实现何种 *** 作。
运行时的多态性:运行时的多态性就是指直到系统运行时,才根据实际情况决定实现何种 *** 作。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)