2012年C++专家进阶之三

简介: 2012年C++专家进阶之三 问题:为什么构造函数不能是虚函数 方法:反证法 证明:假设构造函数是虚拟函数。 方法一:通过覆盖的概念来进行反证 如果派生类或者说子类,写成和基类、父类一模一样的函数,也就是函数说,名称相同,而且参数也相同。

2012C++专家进阶之三

问题:为什么构造函数不能是虚函数

方法:反证法

证明:假设构造函数是虚拟函数。

方法一:通过覆盖的概念来进行反证

如果派生类或者说子类,写成和基类、父类一模一样的函数,也就是函数说,名称相同,而且参数也相同。

注意:基类是虚函数,是带关键字virtual的。

满足覆盖的条件:

1.分属于不同类,子类与基类;

2.基类的函数带virtual关键字;

3.函数名称相同;

4.参数也相同;

 

根据构造函数实现,总是先构造基类对象,但是又根据《2012C++专家进阶之二》,子类的构造函数又将覆盖基类的构造函数,将造成无法构造基类对象,从而出错。矛盾!

方法二:通过虚函数的实现原理来是反证

  理论:虚函数是通过访问一张虚函数表(Virtual Table,简称VTable)来实现的。VTable存储的是对象实例的内存空间信息,也就是各个虚函数的地址信息。

既然构造函数是虚函数,那么就需要访问VTable表,可是对象都还没有实例化,内存空间都还没有申请分配呢,内存空间都还没有,又去哪儿找VTable表?矛盾!

 

   也就是说VTable虚函数表是在构造函数调用之后,才生成的。

相关文章
|
1月前
|
存储 C++ 容器
C++进阶--mep和set的模拟实现
C++进阶--mep和set的模拟实现
|
1月前
|
测试技术 C++
C++进阶--红黑树
C++进阶--红黑树
C++进阶--多态
C++进阶--多态
|
26天前
|
算法 安全 编译器
C++:模版进阶 | Priority_queue的模拟实现
C++:模版进阶 | Priority_queue的模拟实现
|
27天前
|
存储 算法 数据管理
【C++入门到精通】C++入门 ——搜索二叉树(二叉树进阶)
在C++中,本文介绍了搜索二叉树(二叉搜索树,BST)的概念和基本操作,包括搜索、插入和删除。搜索操作从根节点开始,按值大小决定左右查找;插入操作找到合适位置新建节点;删除操作需考虑无子节点、单子节点和双子节点的情况。文中还提供了非递归和递归实现的C++代码示例。此外,讨论了搜索二叉树在K模型和KV模型中的应用以及性能分析,强调了保持树平衡的重要性。
15 0
|
29天前
|
存储 安全 程序员
【C++ 包装器类 智能指针】完全教程:std::unique_ptr、std::shared_ptr、std::weak_ptr的用法解析与优化 — 初学者至进阶指南
【C++ 包装器类 智能指针】完全教程:std::unique_ptr、std::shared_ptr、std::weak_ptr的用法解析与优化 — 初学者至进阶指南
67 0
|
1月前
|
存储 C++
C++进阶--AVL树
C++进阶--AVL树
|
1月前
|
存储 C++ 容器
C++进阶-- map和set
C++进阶-- map和set
|
1月前
|
C++
C++进阶--搜索二叉树
C++进阶--搜索二叉树
|
1月前
|
编译器 C++
C++进阶--继承
C++进阶--继承