zoukankan      html  css  js  c++  java
  • C++虚函数的缺陷

    MFC中的消息机制没有采用C++中的虚函数机制,原因是消息太多,虚函数内存开销太大。在Qt中也没有采用C++中的虚函数机制,原因与此相同,其实这里还有更深层次上的原因,大体说来,多态的底层实现机制只有两种:
    1. 一种是按照名称查表
    2. 一种是按照位置查表
    两种方式各有利弊,而C++的虚函数机制无条件的采用了后者,导致的问题就是在子类很少覆盖基类函数实现的时候内存开销太大,再加上象界面编程这样子类众多的情况(大概是都不覆盖),基本上C++的虚函数机制就废掉了,于是各家库的编写者就只好自谋生路了,说到底,这确实是C++语言本身的缺陷。

    参考:http://blog.csdn.net/oowgsoo/article/details/1529411
    ----------------------------------------------------------------------------------
    感叹一句,还真的是自谋生路啊,而且是不约而同的,Delphi就采用了dynamic机制,以减小子类的内存开销,而且大多数是不必要的虚函数开销。

    在这些方法里:
    1. VC++使用一组结构体的宏定义来实现消息映射,从而解决虚函数的缺陷。
    2. Qt的信号槽机制其实就是按照名称查表。
    3. Delphi则通过dynamic机制从编译器的角度来解决这个问题。这些方法里,自然是Delphi的方法最简洁方便,因为没有多余的宏,没有生成的临时代码。

    ----------------------------------------------------------------------------------
    以前一直不明白为什么说Delphi语法优美,现在有2点体会,好像是这么回事:
    1. C++的宏定义表面上是个好东西,也确实是个好东西,因为可以做无穷无尽的扩展(QT就是一个典型的例子),但用它就会把源代码搞的很复杂,你完全都不知道编译器/类库会把你的源代码替换成什么东西。VC++也是靠这套方法实现消息机制的,QT更夸张,每个文件都要生成moc文件才能真正进行编译。而Delphi的源代码就是源代码,对所有人/所有库都平等,没有什么隐晦的代码。
    2. Delphi的编译器做了很多事情,Delphi的库也提前把许多事情都做好了(比如TPageControl如果要在VC++和QT中实现,使用起来烦不胜烦,谁用谁知道),使之手敲的代码看起来尽可能的少。

  • 相关阅读:
    [转]理解java的三大特性之多态
    [转]java:IO流学习小结
    Base64 加密之中文乱码
    piwik优化之定时任务生成统计数据
    php统计中英文混合的文章字数
    Linux常用命令之定时任务
    skype在线状态代码详解
    php+google/baidu翻译接口
    php限制文件下载速度的代码
    PHP破解wifi密码(wifi万能钥匙的接口)
  • 原文地址:https://www.cnblogs.com/findumars/p/4021383.html
Copyright © 2011-2022 走看看