当前位置:首页 > 芯闻号 > 充电吧
[导读]C++11之前的状况构造函数多了以后,几乎必然地会出现代码重复的情况,为了避免这种情况,往往需要另外编写一个初始化函数。例如下面的Rect类:struct Point{     int x;     

C++11之前的状况


构造函数多了以后,几乎必然地会出现代码重复的情况,为了避免这种情况,往往需要另外编写一个初始化函数。例如下面的Rect类:


struct Point{
    int x;
    int y;
};
struct Rect{
    Rect(){
        init(0, 0, 0, 0, 0, 0);
    }
    Rect(int l, int t, int r, int b){
        init(l, t, r, b, lc, fc, 0, 0);
    }
    Rect(int l, int t, int r, int b, 
          int lc, int fc){
        init(l, t, r, b, lc, fc);
    }
    Rect(Point topleft, Point bottomright){
        init(topleft.x, topleft.y, 
        bottomright.x, bottomright.y,
        0, 0);
    }
    init(int l, int t, int r, int b, 
          int lc, int fc){
        left = l; top = t;        
        right = r; bottom = b;
        line_color = lc;
        fill_color = fc;
        //do something else...
    }
    int left;
    int top;
    int right;
    int bottom;
    int line_color; 
    int fill_color;    
};


数据成员初始化之后要进行某些其他的工作,而这些工作又是每种构造方式都必须的,所以另外准备了一个init函数供各个构造函数调用。


这种方式确实避免了代码重复,但是有两个问题:


没有办法不重复地使用成员初始化列表

必须另外编写一个初始化函数。


C++11的解决方案


C++11扩展了构造函数的功能,增加了委托构造函数的概念,使得一个构造函数可以委托其他构造函数完成工作。使用委托构造函数以后,前面的代码变成下面这样:


struct Point{
    int x;
    int y;
};
struct Rect{
    Rect()
        :Rect(0, 0, 0, 0, 0, 0)
    {
    }
    Rect(int l, int t, int r, int b)
        :Rect(l, t, r, b, 0, 0)
    {
    }
    Rect(Point topleft, Point bottomright)
        :Rect(topleft.x, topleft.y,
             bottomright.x, bottomright.y,
             0, 0)
    {
    }
    Rect(int l, int t, int r, int b,
         int lc, int fc)
        :left(l), top(t), right(r),bottom(b),
          line_color(lc), fill_color(fc)
    {
        //do something else...
    }
    int left;
    int top;
    int right;
    int bottom;
    int line_color;
    int fill_color;
};


真正的构造工作由最后一个构造函数完成,而其他的构造函数都是委托最后一个构造函数完成各自的构造工作。这样即去掉了重复代码又避免了前一种方法带来的问题。


通过代码可以看出:委托构造函数的语法和构造函数中调用基类构造函数一样。调用顺序,效果什么也差不多。


作者观点


DRY(Don't repeat yourself )也需要开发环境的支持。


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

其实在 c++语言里面const修饰的才算是一个真正的常量,在 c 语言中 const 可以说是个“冒牌货”。为什么会这样?其实是 c++ 编译器对 const 进行了加强,当 c++ 编译器遇到常量声明时,不会像 c...

关键字: c++ C语言 const

返回函数的引用去初始化一个新的引用这个和前面一样,都是不会产生副本,但是现在是用返回值去初始化一个引用声明c,也就是说这时候变成了变量temp的别名,在c的生命周期内temp是一直有效的,这样做完全可以。

关键字: c++ 返回值 引用声明

C++是一种面向对象的高级程序设计语言,是C语言的超集。

关键字: c++ C语言

众所周知,在java里是不能给构造函数写返回值的,如果在低版本的编译器定义一个构造器写上返回值可能会报错,高版本里面他就是一个普通的方法。可如果构造函数没有返回值,比如Test t = new Test()我们new一个...

关键字: 构造函数 java

分析:这是Adobe 公司2007 年校园招聘的最新笔试题。这道题除了考察应聘者的C++ 基本功底外,还能考察反应能力,是一道很好的题目。 在Java 中定义了关键字final ,被final 修饰的

关键字: c++ class

泛型算法中的定制操作很多算法都会比较输入序列中的元素,通过定制比较动作,可以控制算法按照编程者的意图工作。本文以string排序为例进行说明,首先是缺省的排序动作: vector v{"This","

关键字: c++

为什么是lambda?讲了这么多天的lambda表达式,有一个很基本的问题没有回答:为什么叫lambda表达式呢?首先这个lambda就是罗马字母λ,lambda表达式即λ表达式。数学上有一个概念叫λ

关键字: c++

        假设我们有个函数用来揭示处理程序的优先权,另一个函数用来在某动态分配所得的Widget 上进行某些带有优先权的处理:int priority () ; void processWi

关键字: c++ effective

判断链表中是否有环最经典的方法就是快慢指针,同时也是面试官大多想要得到的答案。       快指针pf(f就是fast的缩写)每次移动2个节点,慢指针ps(s为slow的缩写)每次移动1个节点,如果快

关键字: c++ 链表 快慢指针

转载请注明出处:http://blog.csdn.net/callon_h/article/details/52073268 引子 上一篇博客从内核驱动到android app讲述了android通过

关键字: c++ java
关闭
关闭