循环通过未知大小的C++数组

Loop through array of unknown size C++

本文关键字:C++ 数组 未知 循环      更新时间:2023-10-16

我正试图遍历一个未知大小的double数组。

为什么以下不起作用?

for (unsigned int = 1; i < sizeof(anArray)/sizeof(double); i++) {
    ...
}

一切都编译得很好(g++ -Wall -Werror -std=c++11 app.cpp -o app),但程序根本不进入循环。

全功能:

struct stock_data {
   int sell_index;
   int buy_index;
   double profit;
};
stock_data max_profit(double price_array[]) {
   int sell_index = -1, buy_index = -1, 
      min = 0;
   double profit = 0.0;
   for(int i = 1; i < size; i++) {
      if(price_array[i] - price_array[min] > profit) {
         sell_index = min;
         buy_index = i;
         profit = price_array[i] - price_array[min];
      }
      if(price_array[i] < price_array[min]) {
        min = i;
      }
   }  
   return {sell_index, buy_index, profit};
}
int main() {
   double yesterday[] = {0.1, 0.2, 0.3, 0.4};
   stock_data data = max_profit(yesterday);
   cout << data.profit << endl;
}

在C++中,sizeof运算符是一个编译时运算符。这就是它的值是由编译器计算的,而不是在运行时。

因此,如果您所说的数组大小未知,那么编译器无法计算数组占用的内存大小。

所以很明显,anArray是指向数组的第一个元素的指针,您可以将它传递给函数。

因此这个表达式

sizeof(anArray)/sizeof(double)

相当于表达式

sizeof( double * )/sizeof( double ).

您还必须将数组的大小显式传递给函数。

请考虑,通过值传递给函数的数组将转换为指向其第一个元素的指针。

或者另一种方法是使用continer std::vector<double>而不是数组。

你可以像一样声明你的函数

stock_data max_profit(double price_array[], size_t size );

并称之为

 stock_data data = max_profit( yesterday, 
                               sizeof( yesterday ) / sizeof( *yesterday ) );

sizeof(anArray)返回类型anArray的大小,可能是*double。您必须将数组大小作为附加参数传递,或者使用std::vector及其size方法。

看看C主函数main(argc, argv),其中argv是程序的参数,argc是它们的计数。或者取字符串,它们的结束由一个特殊字符\0决定,该字符决定其结束。但这很容易出错。

在C/C++中,数组没有其他方法。

如果你真的想避免传递大小,你可以在数组的末尾添加一个NaN,并在循环中检查它。

#include<cmath>
...
for(int i = 0; !isnan(price_array[i]; i++){
    ...
}

在声明数组时添加NaN:

double price_array{0.0d, 5.9d, nan()};

当然,这是假设您的数组中没有任何其他NaN作为实际数据的一部分。

函数max_profit不知道数组price_array的大小。如果你想让函数接受不同大小的数组,你有两个选项:

  • size值与数组一起传递(C样式)
  • 使用内部包含sizestd::vector对象(C++样式)