最新公告
  • 欢迎您光临波比源码,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入我们
  • effective C++ 读书笔记 条款36-37

    条款36:绝不重新定义继承而来的non-virtual函数

    重要点:non-virtual函数都是静态绑定

    // 1241.cpp : 定义控制台利用程序的入口点。
    //

    #include "stdafx.h"
    #include <iostream>
    using namespace std;

    class Base
    {
    public:
    void func()
    {
    cout<<"Base::func()"<<endl;
    }
    };

    class Derived : public Base
    {
    public:
    void func()
    {
    cout<<"Derived::func()"<<endl;
    }
    };
    int _tmain(int argc, _TCHAR* argv[])
    {

    Derived test;
    Base* pB = &test;

    Derived* pD = &test;

    pB->func();//调用Base::func()
    pD->func();//调用Derived::func()
    /*
    这里我们讨论的不是关于隐藏的问题;上面pB指向1个子类,但是调用的是父类的func()函数,至于为何,由于不是虚函数,没有virtual;
    要明白1点:non-virtual函数 Base::func and Derived::func都是静态绑定的,pB被声明为1个人 pointer-to-Base,通过pB调用的non-virtual
    函数永久是Base所定义的版本,即便pB指向1个类型为它的派生类的对象。
    pD 调用的是Derived的函数版本,这里也能够说成是隐藏,但是终究缘由是由于 静态绑定。
    1般 Derived dTest,dTest.func()这样调用我们1般说是由于隐藏。对对象,而我们本例子当中对应的是指针或援用,是由于静态绑定!

    */

    getchar();
    return 0;
    }

    总上:任何情况下都不应当重新定义1个继承而来的non-virtual函数;

    对1个基类来讲,如果1个函数定义为非虚函数,那末意味着这个函数其实不想改变,所以子类不应当继承它,1个类当中的非虚函数,不变性凌驾于其特异性上。

     

    条款37:绝不重新定义继承而来的缺省参数值:

    virtual函数是动态绑定,缺省参数值是静态绑定;

     

    // 1240.cpp : 定义控制台利用程序的入口点。
    //

    #include "stdafx.h"
    #include <iostream>
    using namespace std;

    class Shape
    {
    public:
    enum ShapeColor{Red,Green,Blue};
    virtual void draw(ShapeColor color = Red) const = 0;

    };

    class Rectangle:public Shape
    {
    public:
    virtual void draw(ShapeColor color = Green) const
    {
    cout<<"Rectangle"<<endl;
    }
    };

    class Circle : public Shape
    {
    public:
    virtual void draw(ShapeColor color) const
    {
    cout<<"Circle"<<endl;
    }
    };

    int _tmain(int argc, _TCHAR* argv[])
    {

    Shape* ps;
    Shape* pc = new Circle;
    Shape* pr = new Rectangle;

    pr->draw();//这里调用的是Rectangle的draw函数,但是函数参数color却是Shape父类里面的参数
    /*
    virtual函数是动态绑定,而缺省参数值却是静态绑定。
    这就出现了上面的 调用1个定义于子类的virtual函数,同时却使用base class为它所指定的缺省参数值。
    pr的动态类型是Rectangle*,所以调用的是Ractangle的virtual函数,但是由于pr的静态类型是Shape*,所以此
    函数调用的缺省参数值却是来自鱼Shape Class.
    */
    getchar();
    return 0;
    }

    总结:不要重新定义1个继承而来的缺省参数值,由于缺省参数值是静态绑定的,而virtual函数–你唯1应当覆写的东西–却是动态绑定!!

     

    波比源码 – 精品源码模版分享 | www.bobi11.com
    1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
    2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
    3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
    4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
    5. 如有链接无法下载、失效或广告,请联系管理员处理!
    6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
    7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!

    波比源码 » effective C++ 读书笔记 条款36-37

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    波比源码
    一个高级程序员模板开发平台
    升级波友尊享更多特权立即升级