1

我正在尝试从如下所示的文本文件中加载数据:

161,77,88,255 0,44,33,11,111

等等。我有操作它的函数,并确保数组的大小正确(可能仍然不同)。以下是我的实施尝试:

bool loadData(int **imgPix, string fileName) {

ifstream inputFile;

inputFile.open(fileName.c_str());

string tempLineRow; //The resulting line from the text file
string tempElementColumn; //The individual integer element 
int numberOfCols = 0;
int numberOfRows = 0;


if (!inputFile.is_open()) {
    return false;
}

imgPix = new int* [numberOfRows];

    while (getline(inputFile, tempLineRow, '\n')) {

        stringstream ss; 
        ss << tempLineRow; //Stringstream version of the line

        while (getline(ss, tempElementColumn, ',' )) {
            stringstream ss2; 
            ss2 << tempElementColumn;
            ss2 >> numberOfCols;

//Prob?         (**imgPix) = *(*(imgPix + numberOfRows) + numberOfCols);
            numberOfCols++;

        }

        numberOfRows++;

    }   

inputFile.close();
return true;

}

我已经用注释标记了带有双指针赋值的行,因为我相信它是我的错误的根源,尽管可能还有其他错误。我不确定如何使用我实现的 while 循环结构来迭代更新 2D 数组。

任何人都可以提供任何帮助吗?将不胜感激!

4

3 回答 3

0

您的代码有几个问题,我猜主要是因为您没有完全理解内置数组在 C++ 中的工作原理。这里的主要问题是那些不能轻易动态增长,这些数组没有“调整大小”操作(但你需要一个)。因此,我建议您尝试使用std::vector<int>and重写代码std::vector< std::vector<int> >,确保.resize在存储新行或新列时使用 ,并在遇到此新实现的问题时再次询问。

于 2013-05-18T12:13:55.687 回答
0
imgPix = new int* [numberOfRows]

这里 numberOfRows = 0,所以你没有分配足够的内存。在分配内存之前,您需要知道数组的维度。然后你还应该为数组中的每一行分配一个内存:

imgPix[currentRow] = new int [TotalCols];

对于二维矩形数组,创建 TotalRows*TotalCols 元素的一维数组,然后使用 formula 访问它会更有效A(row, col) = A[row*TotalCols + col]

于 2013-05-18T12:15:41.317 回答
0

以前的答案是有效的,但是如果不需要连续内存,那么std::deque在这种情况下 s 可能是比std::vectors 更好的选择,以避免大量内存重新分配。

于 2013-05-18T12:37:13.310 回答