找不到无限循环的位置

时间:2012-10-18 01:05:51

标签: c++ arrays for-loop infinite-loop

我正在制作一个程序,用户输入30天的收盘价格,程序会找到最低价格和最高价格。

用户输入数据后,程序将无法继续。

double highest = stockPrices[0];
double lowest = stockPrices[0];

for(int j = 0; j < sizeof(stockPrices) + 1; j++) {
     if(stockPrices[j] > highest) {
      highest = stockPrices[j];
     }   
     if(stockPrices[j] < lowest) {
      lowest = stockPrices[j];
     } 
}

但我无法找到无限循环的位置。


for(int i = 0; i < sizeof(stockPrices) + 1; i++) {
    cin >> stockPrices[i];
}

这部分工作正常,这就是为什么我没有意识到我的上限不正确 编辑:我认为这部分工作正常

1 个答案:

答案 0 :(得分:5)

没有足够的代码来确定问题所在。但只是在那个片段中你可能有错误的上限:

for (int j = 0; j < sizeof(stockPrices) / sizeof(stockPrices[0]); j++)

sizeof以字节为单位给出对象的大小。对于一个数组,它是项目数×一个项目的大小。因此,要获得所需的项目数,需要将sizeof除以一个项目的大小。

你可能也不想要+1

请注意,您编写的循环将在有或没有此更正的情况下终止。它将在您的版本中运行超过数组的末尾并访问非法内存,这可能会使程序崩溃,但它不会永远循环。


同样的事情适用于你的第二个循环。它应该是:

for (int i = 0; i < sizeof(stockPrices) / sizeof(stockPrices[0]); i++)
{
    cin >> stockPrices[i];
}

这里不正确的上限可能的罪魁祸首。您的原始循环将尝试读取超过30个值。如果只提供了30个,则程序将在第31个cin >> stockPrices[i]挂起,等待输入更多数字。