1、基类中虚函数定义:
(1) c++中成员函数默认为非虚函数,为了指明函数为虚函数,需在其前面加上保留字virtual。
(2) 除了构造函数之外,任意非static成员函数可以是虚函数。
(3) 基类通常应将派生类需要重定义的任意函数定义为虚函数
class Base
{
public:
Base():isbn(""),price(10){};
Base(string i,double p):isbn(i),price(p){}
string book()const{return isbn;}
virtual double net_price(int n)const
{return n*price;}
private:
string isbn;
protected:
double price;
};
2、派生类重定义虚函数:
(1)派生类一般会重定义虚函数,但不一定要这样做。
(2)派生类中虚函数的声明必须与基类中的定义方式完全匹配。
class Item : public Base{
public:
Item(int n, double d,string i,double p):min_qty(n),discount(d){Base(i,p);}
double net_price(int n)const;
private:
int min_qty;
double discount;
};
double Item::net_price(int cnt)const
{
if(cnt>min_qty)
return cnt*(1-discount)*price;
else
return cnt*price;
}
3、运行时确定virtual函数的调用
通过指针或者应用调用虚函数的时候,编译器将生成代码,在运行时确定调用哪个虚函数,被调用的是与动态类型相对应的函数。
void print(const Base& item,int n)
{
cout<<"\ntotal price"<<item.net_price(n);
}
int main()
{
Base base("IS123",10);
Item item(5,0.75,"IS123",10);
print(base,10);//调用Base::net_price()
print(item,10);//调用Item::net_price()
}
引用基类引用或者指针调用基类中定义的函数,我们并不知道执行函数的对象的确切类型,执行函数的时候可能是基类类型,也可能是派生类类型。