1.纯虚函数
什么是纯虚函数?
没有函数体的虚函数,如:
virtual void print() = 0;
什么是抽象类?
有一个及其以上的纯虚函数的类,称之为抽象类。
//抽象类
class Object
{
public:
//纯虚函数
virtual void print() = 0;
protected:
};
抽象类的特点:
不能构建对象,可以构建对象指针。
一般拿来充当中间访问层。
2.ADT过程
别人写好了一个抽象类给你,就好比下发了一个任务。需要你去实现
class List
{
public:
//防止析构问题
virtual ~List() //抽象类被继承 使用这种方式
{
cout << "list的析构函数" << endl;
}
virtual void push_back(int element) = 0;
virtual void push_front(int element) = 0;
virtual void pop_back() = 0;
virtual int front() = 0;
virtual void pop_front()=0;
virtual int size() const = 0;
virtual int empty() const = 0;
};
发给我们干嘛?又不能构建对象,没办法,我们只能去实现一下这些功能,让它可以构建对象。
这个时候子类应该怎么写?(假装已经实现功能)
子类的virtual可写可不写,写不写它都是虚函数。
class arrayList:public List
{
public:
~arrayList()
{
cout << "arrayList的析构函数" << endl;
}
virtual void push_back(int element) {}
virtual void push_front(int element) {}
virtual void pop_back() {}
virtual void pop_front() {}
virtual int front() { return 1; };
//常成员函数: 特性,不能数据数据成员,常对象只能调用常成员函数
virtual int size() const { return 0; }
virtual int empty()const { return 0; }
};
3.虚析构函数
父类中我们写的是
virtual ~List() //抽象类被继承 使用这种方式
{
cout << "list的析构函数" << endl;
}
1.virtual 作用:实现父类指针调用子类成员
2.虚析构函数实现非正常情况下的指针赋值导致的析构函数。父类指针被子类对象初始化,父类的析构函数必须使用虚析构函数
多态我们怎么搞得?
首先就是为了解决纵向重载的问题,我们把父类函数写作虚函数,实现父类指针使用子类方法。
这里可以理解为,底层析构函数是同名的。