C ++浮点数组初始化

时间:2012-10-08 22:12:28

标签: c++ arrays floating-point initialization

  

可能重复:
  C and C++ : Partial initialization of automatic structure

在阅读Code Complete时,我遇到了一个C ++数组初始化示例:

float studentGrades[ MAX_STUDENTS ] = { 0.0 };

我不知道C ++可以初始化整个数组,所以我测试了它:

#include <iostream>
using namespace std;

int main() {
    const int MAX_STUDENTS=4;
    float studentGrades[ MAX_STUDENTS ] = { 0.0 };
    for (int i=0; i<MAX_STUDENTS; i++) {
        cout << i << " " << studentGrades[i] << '\n';
    }
    return 0;
}

该计划给出了预期的结果:

0 0
1 0
2 0
3 0

但是将初始值从0.0更改为9.9

float studentGrades[ MAX_STUDENTS ] = { 9.9 };

给出了有趣的结果:

0 9.9
1 0
2 0
3 0

初始化声明是否只设置数组中的第一个元素?

2 个答案:

答案 0 :(得分:28)

如果你使用除空括号之外的任何东西,那么你只将前N个位置初始化为该值,所有其他位置初始化为0.在这种情况下,N是你传递给初始化列表的参数数量,即

float arr1[10] = { };       // all elements are 0
float arr2[10] = { 0 };     // all elements are 0
float arr3[10] = { 1 };     // first element is 1, all others are 0
float arr4[10] = { 1, 2 };  // first element is 1, second is 2, all others are 0

答案 1 :(得分:5)

不,它将所有未明确设置为默认初始化值的成员/元素设置为数字类型为零。