静态联编与动态联编
联编:
程序自身彼此关联的过程,确定程序中的操作调用与执行该操作的代码间的关系 。
静态联编(静态束定)
联编工作出现在编译阶段,用对象名或者类名来限定要调用的函数。
动态联编
联编工作在程序运行时执行,在程序运行时才确定将要调用的函数。
虚函数:
虚函数是动态联编的基础。
1, 是非静态的成员函数。
2, 在类的声明中,在函数原型之前写virtual。
3, virtual 只用来说明类声明中的原型,不能用在函数实现时。
4, 具有继承性,基类中声明了虚函数,派生类中无论是否说明,同原型函数都自动为虚函数。
5, 本质:不是重载声明而是覆盖。(因为其不属于函数签名部分)
6, 调用方式:通过基类指针或引用,执行时会 根据指针指向的对象的类,决定调用哪个函数。
虚析构函数:
为了保正析构函数能够被正确的调用,因此析构函数一般都被声明为虚函数(除非此类不会被继承),我们称其为虚析构函数。
如:
class Base
{
public:
virtual ~Base() { cout << "Base Destructor/n"; }
};
class Derived
{
public:
virtual ~Derived() { cout << "Derived Destructor/n"; }
};
int main()
{
Base *b = new Derived();
delete b;
}
output:
Derived Destructor
Base Destructor
我以前好像做过这样的笔记,现在却不是很清楚了,呵呵。笔记如下:
用多态性处理动态分配的类层次结构中的对象时存在一个问题。
如果delete运算符用于指向派生类对象的基类指针,而程序中又显示地调用该运算符删除每一个对象,
那么,不管基类指针所指向的对象是何种类型,也忽略每一个类的析构函数名的不相同,系统都会为这些对象调用基类的析构函数。
联编:
程序自身彼此关联的过程,确定程序中的操作调用与执行该操作的代码间的关系 。
静态联编(静态束定)
联编工作出现在编译阶段,用对象名或者类名来限定要调用的函数。
动态联编
联编工作在程序运行时执行,在程序运行时才确定将要调用的函数。
虚函数:
虚函数是动态联编的基础。
1, 是非静态的成员函数。
2, 在类的声明中,在函数原型之前写virtual。
3, virtual 只用来说明类声明中的原型,不能用在函数实现时。
4, 具有继承性,基类中声明了虚函数,派生类中无论是否说明,同原型函数都自动为虚函数。
5, 本质:不是重载声明而是覆盖。(因为其不属于函数签名部分)
6, 调用方式:通过基类指针或引用,执行时会 根据指针指向的对象的类,决定调用哪个函数。
虚析构函数:
为了保正析构函数能够被正确的调用,因此析构函数一般都被声明为虚函数(除非此类不会被继承),我们称其为虚析构函数。
如:
class Base
{
public:
virtual ~Base() { cout << "Base Destructor/n"; }
};
class Derived
{
public:
virtual ~Derived() { cout << "Derived Destructor/n"; }
};
int main()
{
Base *b = new Derived();
delete b;
}
output:
Derived Destructor
Base Destructor
我以前好像做过这样的笔记,现在却不是很清楚了,呵呵。笔记如下:
用多态性处理动态分配的类层次结构中的对象时存在一个问题。
如果delete运算符用于指向派生类对象的基类指针,而程序中又显示地调用该运算符删除每一个对象,
那么,不管基类指针所指向的对象是何种类型,也忽略每一个类的析构函数名的不相同,系统都会为这些对象调用基类的析构函数。