virtual关键字的作用:1.派生类可以通过重写来覆盖基类的虚拟函数,
当基类的指针指向派生类的对象时,调用函数调用的即是派生类中重写的虚拟函数,
至此便实现了面向对象的多态性
2.纯虚函数 virtual void play() = 0;充当接口的作用。其派生类必须重写纯虚函数,
否则会报错
3.虚拟继承 为了解决从不同途径继承来的同名的数据成员在内存中有不同的拷贝造成数据不一致问题,
将共同基类设置为虚基类。这时从不同的路径继承过来的同名数据成员在内存中就只有一个拷贝,
同一个函数名也只有一个映射。这样不仅就解决了二义性问题,也节省了内存,避免了数据不一致的问题。
class 派生类名:virtual 继承方式 基类名
当基类的指针指向派生类的对象时,调用函数调用的即是派生类中重写的虚拟函数,
至此便实现了面向对象的多态性
2.纯虚函数 virtual void play() = 0;充当接口的作用。其派生类必须重写纯虚函数,
否则会报错
3.虚拟继承 为了解决从不同途径继承来的同名的数据成员在内存中有不同的拷贝造成数据不一致问题,
将共同基类设置为虚基类。这时从不同的路径继承过来的同名数据成员在内存中就只有一个拷贝,
同一个函数名也只有一个映射。这样不仅就解决了二义性问题,也节省了内存,避免了数据不一致的问题。
class 派生类名:virtual 继承方式 基类名
virtual是关键字,声明该基类为派生类的虚基类。
#include "stdafx.h"
#include<iostream>
using namespace std;
/* virtual关键字的作用:1.派生类可以通过重写来覆盖基类的虚拟函数,
当基类的指针指向派生类的对象时,调用函数调用的即是派生类中重写的虚拟函数,
至此便实现了面向对象的多态性
2.纯虚函数 virtual void play() = 0;充当接口的作用。其派生类必须重写纯虚函数,
否则会报错
3.虚拟继承 为了解决从不同途径继承来的同名的数据成员在内存中有不同的拷贝造成数据不一致问题,
将共同基类设置为虚基类。这时从不同的路径继承过来的同名数据成员在内存中就只有一个拷贝,
同一个函数名也只有一个映射。这样不仅就解决了二义性问题,也节省了内存,避免了数据不一致的问题。
class 派生类名:virtual 继承方式 基类名
virtual是关键字,声明该基类为派生类的虚基类。
*/
class A{
public:
/*virtual A(){
}*/
virtual void sayHello(){
cout << "hello world.this is A"<<endl;
}
};
class B :public A{
public:
void sayHello(){
cout << "hello world.this is B" << endl;
}
};
int _tmain(int argc, _TCHAR* argv[])
{
A *b=new B();
b->sayHello();
system("pause");
return 0;
}
#include "stdafx.h"
#include"iostream"
using namespace std;
class Ifootball{
virtual void play() = 0;
virtual void myName() = 0;
};
class football :Ifootball{
public:
static string name;
void play(){
cout << "play";
}
void myName(){
cout << "my name is football";
}
static void sayHello(){
cout << "hello";
}
};
int _tmain(int argc, _TCHAR* argv[])
{
football::name = "football";//类名::静态成员
football::sayHello();
football ff;
ff.sayHello();
ff.name = "football";
ff.myName();
ff.play();
char a;
cin >> a;
return 0;
}