C++构造函数与初始化列表

本文探讨了C++中构造函数的作用与重要性,解释了为何在定义变量时直接初始化能减少程序错误。深入讨论了构造函数初始化列表的概念,说明了它如何解决效率问题及避免因使用默认构造函数引发的错误。特别强调了在MFC中初始化列表的应用,以及const型成员变量为何只能在构造函数初始化列表中定义。
        C++引入构造函数的目的在于对变量的初始化做出强制,因为人们发现,程序的错误,很大程度上来说,都是由变量没有初始化造成的。

        因此,一种很好的编程习惯就是,在定义变量的时候直接初始化。而在C++中,在变量定义时,系统会自动调用变量的构造函数对变量进行初始化。只要将相应的初始化代码放在构造函数中,就能够保证该类在实例化对象的时候能够给对象赋以理想的初值。

        而事实远远没有这么简单。

        实际上,程序在进入构造函数的大括号体时,就已经完成了变量的定义(也就是分配内存空间)。这就难免会造成这样的一种情况:在对象被构造时,程序进入构造函数大括号体之前,首先调用对象的default构造函数,然后进入构造函数体内,重新对变量进行赋值。这无疑降低了程序的效率。

        还有更糟糕的情况。

        如果一个对象必须经由一个非default构造函数进行定义才能够在将来被正常地赋值,而系统默认地调用了它的default构造函数,就会出现很大的错误。

        因此,C++的设计者引入了构造函数初始化列表的概念。也就是说,在构造函数的初始化列表之中进行的是对变量的定义与初始化(分配内存空间),而不是简单的赋值。这样就能够解决上述的效率以及对构造函数的选择的问题。

        这一点在MFC中体现得尤为明显。继承的类一般会在初始化列表中调用能够其父类的构造函数。

        应为在初始化列表中发生的是成员变量的定义,也就是分配空间,因此初始化列表中构造的顺序与实际编译器定义变量的顺序可能是不一致的,也就是说,编译器不会按照设计者在初始化列表中初始化变量的顺序来为变量分配内存空间。初始化列表中变量的初始化顺序时其在类体内定义的顺序。

        同样得,因为const型成员变量只能在被定义的同时被初始化而不能够再次被赋值,它也只能被放在构造函数的初始化列表中。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值