面向对象特点
A:
封装,继承,多态
Q:
抽象类
A:
抽象类是特殊的类,只是不能被实例化(将定义了纯虚函数的类称为抽象类);除此以外,具有类的其他特性;抽象方法只能声明于抽象类中,且不包含任何实现,派生类必须覆盖它们。
另外,抽象类可以派生自一个抽象类,可以覆盖基类的抽象方法也可以不覆盖,如果不覆盖,则其派生类必须覆盖它们。虽然不能定义抽象类的实例,但是可以定义它的指针,这正是用抽象类实现接口的重点所在。
class animal //抽象类(有了纯虚函数才能成为抽象类)
{
public:
virtual ~animal() = 0; //纯虚析构函数
animal (int i = 0){x = i} //构造函数可有可无
virtual void count(float a) = 0; //纯虚函数
protected:
int x;
}
//纯虚函数不能实例化,只有在子类中才能实例化
总结
如果某个类不包含虚函数,那一般是表示它将不作为一个基类来使用。当一个类不准备作为基类使用时,就不要定义虚析构函数了,因为它会增加一个虚函数表,使得对象的体积翻倍,还有可能降低其可移值性。
Q:
虚函数
A:
C++实现运行中的多态性是通过虚函数实现的,而虚函数必须存在于继承环境下。
虚函数是重载的一种表现形式,是一种动态的重载方式。
只有类的普通成员函数可以定义为虚函数,全局函数及静态成员函数(类拥有)不能声明为虚函数。
只有用virtual声明类的成员函数,使之成为虚函数,不能将类外的普通函数声明为虚函数。因为虚函数的作用是允许在派生类中对基类的虚函数重新定义。所以虚函数只能用于类的继承层次结构中。
拓展
根据什么考虑是否把一个成员函数声明为虚函数
Q:
纯虚函数
A:
virtual 函数类型 函数名(形参表列)=0; 抽象类中定义的,为了派生类中的使用而声明定义的,其在基类中没有任何意义
Q:
虚析构函数/纯虚析构函数
A:
如果将基类的析构函数声明为虚函数时,由该基类所派生的所有派生类的析构函数都自动成为虚函数,即使派生类的析构函数与基类的析构函数名字不相同。
virtual ~A(void); //虚析构函数
virtual ~A(void) = 0; //纯虚析构函数 ,所在的类就为抽象类了
如果某个类不包含虚函数,那一般是表示它将不作为一个基类来使用。当一个类不准备作为基类使用时,就不要定义虚析构函数了,因为它会增加一个虚函数表,使得对象的体积翻倍,还有可能降低其可移值性。
Q:
接口
A:
有时候,我们得提供一些接口给别人使用。
接口的作用,就是提供一个与其他系统交互的方法。其他系统无需了解你内部细节,并且也无法了解内部细节,只能通过你提供给外部的接口来与你进行通信。根据c++的特点,我们可以采用纯虚函数的方式来实现。这样做的好处是能够实现封装和多提供给外面使用的接口一般采用纯虚函数。
实现接口是通过继承接口的子类来实现的,不同的子类可以实现不同效果,即所谓多态。
Q:
抽象类与接口的区别
A:
Q:
封装
A:
封装就是通过权限来限制类中的代码外界无法看到更无法更改;
封装可以隐藏实现细节,使得代码模块化;继承可以扩展已存在的代码模块(类);它们的目的都是为了——代码重用。而多态则是为了实现另一个目的——接口重用!即:
1)公有( public )成员可以在类外访问。
2)私有( private )成员只能被该类的成员函数访问。
3)保护( protected )成员只能被该类的成员函数或派生类的成员函数访问。