为什么程序会崩溃?

时间:2012-02-27 15:46:57

标签: c++ crash

我正在制作一个c ++程序,它应该从标准输入读入一个整数N.然后应该从文件“data.txt”读取一个大小为N的数组。然后它应该将它传递给一个反转的函数数组并返回指向新数组的指针。然后它应该打印返回指针的数组的内容。但每次我运行该程序时它都会崩溃。有什么想法吗?

#include <iostream>
#include <fstream>

using namespace std;

int * reverseArray(int * arr, const int size)
{
//int arr1[size];
int *arr2 = new int[size];
for(int iii = 0; iii < size; iii++)
{
    (*(arr2+iii)) = (*(arr + size - 1 - iii));
}

return arr2;
}

int main()
{
int N;
cin >> N;
if(N >= 0 && N <= 50)
{
    ifstream inputFile;
    inputFile.open("data.txt");
    int *arr = new int[N];
    int iii = 0;
    while(inputFile >> (*(arr+iii)) && iii < N)
    {    iii++;}

    arr = reverseArray(arr, N);

    for(int jjj = 0; jjj < N; jjj++)
    {
        cout << (*(arr+jjj)) << endl;
    }

    delete [] arr;
    inputFile.close();
}

return 0;
}

2 个答案:

答案 0 :(得分:6)

我认为问题在于:

while(inputFile >> (*(arr+iii)) && iii < N)

访问后检查以确保iii小于N。重新排序条件:

while(iii < N && inputFile >> (*(arr+iii)) )

注意这一行引入了内存泄漏:

arr = reverseArray(arr, N);

因为这是C ++,所以请考虑使用std::vector<int>

答案 1 :(得分:0)

我建议将其更改为以下内容。虽然会指出你会得到未定义的输出,如果N&lt; data.txt中的项目数。

while (iii < N && inputFile.good())
{
    inputFile >> *(arr+iii);
    ++iii;
}

int *arrRev = reverseArray(arr, N);

for(int jjj = 0; jjj < N; ++jjj)
{
    cout << (*(arrRev+jjj)) << endl;
}

delete [] arr;
delete [] arrRev;
inputFile.close();