C++数组成员的初始化

C++里如果将数组定义成类中的成员,将面临初始化的问题.

 

如下:

 

Class A

{

public:

    A();

    ~A(){};

 

    int abc[3];

}

 

很直观的想法是

 

A::A()

: abc({1,2,3})

{

 

}

 

很遗憾,你将见到编译提示语法错误

 

当然这里可以采用变通方法

 

A::A()

{

    for( int nLoop=1;nLoop<=3;nLoop++)

         abc[nLoop]=nLoop;

}

但假如需要初始化的是没有默认构造的对象数组又如何呢?
例如
class B
{
public:
    B(int a);
    ~B(){};
    int m_nB;
}
B::B(int a)
: m_nB(a)
{
}

Class A

{

public:

    A();

    ~A(){};

 

    B    abc[3];

}

 这时该如何初始化呢?
这里只能用变通的方法解决.

Class A

{

public:

    A();

    ~A(){};

 

    B    *abc[3];

}

A::A()
{
    abc[0] = new B(1);
    abc[1] = new B(2);
    abc[2] = new B(3);
}
当然也许是我太孤陋寡闻了,如果大家谁知道成员数组的初始化语法,恳请告知哦.
### C++ 数组初始化方法 #### 使用传统方式初始化数组 在早期版本的 C++ 中,可以使用传统的花括号语法来初始化数组。这种方式允许指定初始值列表: ```cpp int arr[] = {1, 2, 3, 4, 5}; // 自动推导长度为5的一维整型数组并赋初值[^2] ``` 对于多维数组而言,同样适用此规则: ```cpp int matrix[][3] = { {1, 2, 3}, {4, 5, 6} }; // 定义了一个2×3矩阵,并自动计算外层数组大小为2 ``` #### 利用C++11的大括号初始化器 自 C++11 起支持统一初始化语法(即大括号初始化),这不仅限于容器类对象还扩展到了基本类型的数组上。 这种新的初始化形式能够有效防止窄化转换带来的潜在错误,同时保持了与旧版代码兼容性: ```cpp double values[]{1.0, 2.0, 3.0}; // 明确指定了类型以及元素数量由编译器决定 std::string names[]{"Alice", "Bob"}; // 字符串字面量组成的字符串向量 ``` 当动态分配内存创建数组时也可以采用同样的方式进行初始化: ```cpp auto pArray = new int[5]{0, 1, 2, 3, 4}; // 动态分配的同时完成初始化操作[^1] ``` 需要注意的是,在某些情况下如果不提供具体的尺寸参数,则必须给出完整的初始化列表以便让编译器能正确解析所需空间大小;另外如果省略初始化表达式则意味着所有成员都将被设置成默认值零或空状态取决于具体的数据类型[^3]。 #### 动态数组初始化 除了静态声明之外还可以通过 `new` 关键字来进行堆上的数组实例化工作,此时既可以不给定任何初始值也可利用上述提到的大括号记法来做更精确地控制: ```cpp int* dynamicArr = new int[10]; // 创建未初始化的整形数组 delete[] dynamicArr; float* floatDynArr = new float[7]{1.1f, 2.2f}; // 部分初始化浮点数数组剩余位置会被置零 delete[] floatDynArr; ``` 以上就是几种常见的 C++ 数组初始化的方式介绍[^4].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

b2b160

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值