面向对象的程序设计-5-多态性和虚函数-part1

本文详细介绍了C++中函数重载的概念及其应用,并着重阐述了如何利用派生类的指针实现多态性,通过实例展示了如何通过基类指针访问派生类的成员,强调了C++运行时多态性的关键途径。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

函数的重载是多态性的一种简单体现。普通成员函数的重载可以在类中说明重载,也可以基类的成员函数在派生类中进行重载。有三种的编译区分方法(具体的再查资料呗)。同时C++还提供一种灵活的多态性机制:虚函数。虚函数允许,函数调用与函数体的联系,在运行时候才进行。被称为动态联编。所谓的动态联编是指编译程序在编译阶段并不能确切地知道将要调用的函数,只有在程序执行时才能确定将要调用的函数,为此要确切地知道将要调用的函数,要求联编工作在程序运行时进行。虚函数是动态联编的基础。所以先介绍下派生类的指针再介绍下虚函数。

派生类的指针:

指向基类和派生类的指针是相关的。例如:A *P;//对象指针 A  a;//A的对象    B b//B类的对象    P=&a;//P指向对象a

P=&b;//指向b对象(假设B从A中公有继承)则P可以通过b访问所有从a继承的元素,但是不能用P访问b对象自身特定的元素(除非用显式类型转换)。举个例子吧……

#include <iostream>
using namespace std;
class A
{
private:
char name[20];
public:
void put_name(char *s){strcpy(name,s);}
void show_name(){cout<<name<<"\n";}//<<endl;}//看下这个效果呢?
};
class B:public A
{
private:
char phone_num[80];
public:
void put_phone(char *num){strcpy(phone_num,num);}
void show_phone(){cout<<"phone num is  "<<phone_num<<"\n";}
};
void main()
{
A *p;A a;//p为基类指针,p为对象指针
B *bp;B b;
a.put_name("俞飞鸿");//为什么这个可以通过呢?
a.show_name();
cout<<"========================"<<endl;
p=&a;p->put_name("吴镇宇");p->show_name();
p=&b;p->put_name("李安");p->show_name();//通过对象b访问从A中继承的元素
a.show_name();b.show_name();
cout<<"号码的显式"<<endl;
bp=&b;bp->put_phone("5555555");
bp->show_phone();
((B*)p)->show_phone();//用基类的指针访问公有派生类的特定成员,必须进行类型转换
}

本来p是基类的指针,只能通过对象b访问从A中继承的元素,但是通过指针类型的转换后,将其转换为B类指针,则可以访问派生类中的其他成员。

一个基类的指针是可以指向从基类公有派生的任何对象。此为C++运行时,多态的关键途径。但是不能用指向派生类的指针指向一个基类对象。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值