数组在C ++中自动填充

时间:2014-08-11 09:09:50

标签: c++ arrays cin integer-overflow

我正在学习C ++,做一些简单的例子,并发现了这种奇怪的行为。 当填充整数数组的元素时,如果任何元素设置为大于2147483647(我相信是最大整数值?),则数组中的其余元素将设置为该确切数字,每个其中之一。

我理解如果一个元素超出其类型限制,编译器会将其限制为该限制,但我无法理解为什么它与其他项目做同样的事情,甚至没有要求用户填充它们。 / p>

这是我运行的一个简单测试:

#include <iostream>
using namespace std;

int main()
{
    int test[5];
    int num = 0;

    for (int i=0; i<5; i++)
    {
        cout << "Enter the number in position " << i << endl;
        cin >> num;
        test[i] = num;
    }

    cout << "Values in the array: " <<endl;
    for (int i=0; i<5; i++)
        cout << test[i] << endl;

}

感谢阅读,评论和帮助!

1 个答案:

答案 0 :(得分:7)

std::istream::operator>>的文档:

  

如果提取导致值太大或太小而无法放入value,则会写入std::numeric_limits<T>::max()std::numeric_limits<T>::min()并设置failbit标记。

设置failbit标志后,后续输入操作将不起作用,这意味着aux保持不变。

如果您想在转换失败后继续提取项目,则需要clear failbit:

    cin.clear();
    cin >> aux;