成员初始化列表(member initializer list)

成员初始化列表(member initializer list)

只有构造函数可以使用初始化列表句法。

类对象const成员的动态初始化

 

     对于const数据成员,必须在执行到构造函数之前,即创建对象时进行初始化。因此其构造函数中的初始化方法为:

 

ClassName::ClassName(val):CdataA(val),CdataB(val*2+1){.....;}

 

(成员初始化列表由逗号分隔的初始化列表组成,前面带冒号。它位于参数列表的右括号之后、函数体左括号之前)

 

通常,初值可以是常量或构造函数的参数列表中的形参。
并且,这种方法并不限于初始化常量。

 

初始化引用数据成员

对于在类中被声明为引用的类成员,也必须使用这种方法。因为引用与const数据类似,只能在被创建时进行初始化:

 

class ClassName_A {....};
class ClassName_B
{
 private:
        ClassName_A & belong;
        ....;
};
ClassName_B::ClassName_B (ClassName_A & A):belong(A){...;}

 


 

 

 

    成员初始化列表中使用的括号方式也可用于常规的初始化中。
    可以将下述代码:
    int games = 500;
    double Pi = 3.1415;
替换为:
    int games(500);
    double Pi(3.1415);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
initializer_list是C++11标准引入的一种数据结构,用于表示一个初始化列表。它可以用于函数参数、构造函数、赋值等场合。 初始化列表是由一系列用逗号隔开的值组成的,可以用花括号括起来。例如,{1, 2, 3}就是一个初始化列表,其中包含了三个整数1、2、3。 initializer_list的定义如下: ```cpp template<class T> class initializer_list { public: typedef const T* iterator; typedef const T& reference; typedef size_t size_type; initializer_list() noexcept; initializer_list(const T* p, size_t n) noexcept; size_t size() const noexcept; const T* begin() const noexcept; const T* end() const noexcept; }; ``` 使用initializer_list需要包含头文件<initializer_list>。 可以通过以下方式初始化initializer_list: ```cpp std::initializer_list<int> il = {1, 2, 3}; ``` 在函数参数中使用initializer_list可以方便地传递一组值: ```cpp void foo(std::initializer_list<int> il) { for (auto it = il.begin(); it != il.end(); ++it) { std::cout << *it << std::endl; } } foo({1, 2, 3}); ``` 在类的构造函数中使用initializer_list可以方便地对成员变量初始化: ```cpp class MyClass { public: MyClass(std::initializer_list<int> il) { for (auto it = il.begin(); it != il.end(); ++it) { vec.push_back(*it); } } private: std::vector<int> vec; }; MyClass mc = {1, 2, 3}; ``` 总之,initializer_list是一个十分方便的工具,可以用于各种场合,使代码更加简洁、清晰。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值