#include <iostream>
using namespace std;
class poser
{
public:
virtual void beat()const{cout<<"一般选手一拳的力量为260磅\n";}
protected:
int age;
};
class Ali:public poser
{
public:
void beat()const{cout<<"阿里一拳的力量为420磅\n";}
};
class Lewis:public poser
{
public:
void beat()const{cout<<"刘易斯一拳的力量为480磅\n";}
};
class Tyson:public poser
{
public:
void beat()const{cout<<"泰森一拳的力量为500磅\n";}
};
class holy:public poser
{
public:
void beat()const{cout<<"霍利菲尔德一拳的力量为350磅\n";}
};
void main()
{
poser *a[5];
poser *p;
int choice,i;
for(i=0;i<5;i++)
{
cout<<"(1)阿里(2)刘易斯(3)泰森(4)霍利菲尔德:";
cin>>choice;
switch(choice)
{
case 1:p=new Ali; //选择1时,新建Ali对象,并用指针p来指向它
break; //跳出switch语句
case 2:p=new Lewis;
break;
case 3:p=new Tyson; //选择3时,新建Tyson对象,并用指针p来指向它
break;
case 4:p=new holy; //选择4时,新建holy对象,并用指针p来指向它
break;
default:p=new poser; //默认时,也就是选其他数字,新建poser对象,并用
//指针p来指向它
break;
}
a[i]=p; //将p指针赋给数组元素,元素中保存的是对象地址,
//关于数组的概念后面还要详细讲解。
a[i]->beat(); //通过数组中保存的指针来访问函数,由于是间接访问,所以要
//加指向成员运算符->
} //for循环结束
}
1.如基类某个成员为虚函数,派生类继承来的该函数仍为虚函数,派生类可写virtual,可不写
2.动态联编就是基类指针指向不同的派生类对象时的多态体现,调用不同派生类的重载函数。
using namespace std;
class poser
{
public:
virtual void beat()const{cout<<"一般选手一拳的力量为260磅\n";}
protected:
int age;
};
class Ali:public poser
{
public:
void beat()const{cout<<"阿里一拳的力量为420磅\n";}
};
class Lewis:public poser
{
public:
void beat()const{cout<<"刘易斯一拳的力量为480磅\n";}
};
class Tyson:public poser
{
public:
void beat()const{cout<<"泰森一拳的力量为500磅\n";}
};
class holy:public poser
{
public:
void beat()const{cout<<"霍利菲尔德一拳的力量为350磅\n";}
};
void main()
{
poser *a[5];
poser *p;
int choice,i;
for(i=0;i<5;i++)
{
cout<<"(1)阿里(2)刘易斯(3)泰森(4)霍利菲尔德:";
cin>>choice;
switch(choice)
{
case 1:p=new Ali; //选择1时,新建Ali对象,并用指针p来指向它
break; //跳出switch语句
case 2:p=new Lewis;
break;
case 3:p=new Tyson; //选择3时,新建Tyson对象,并用指针p来指向它
break;
case 4:p=new holy; //选择4时,新建holy对象,并用指针p来指向它
break;
default:p=new poser; //默认时,也就是选其他数字,新建poser对象,并用
//指针p来指向它
break;
}
a[i]=p; //将p指针赋给数组元素,元素中保存的是对象地址,
//关于数组的概念后面还要详细讲解。
a[i]->beat(); //通过数组中保存的指针来访问函数,由于是间接访问,所以要
//加指向成员运算符->
} //for循环结束
}
1.如基类某个成员为虚函数,派生类继承来的该函数仍为虚函数,派生类可写virtual,可不写
2.动态联编就是基类指针指向不同的派生类对象时的多态体现,调用不同派生类的重载函数。