【问题标题】:Segmentation Fault: Dynamically allocating large integer array分段错误:动态分配大整数数组
【发布时间】:2016-11-10 00:44:33
【问题描述】:

我有以下代码,其中包含一个动态分配的数组“数据”。我将数组大小作为命令行参数传递。该程序运行良好,直到 datasize = 33790。如果我尝试提供 > 33790 的值,则会出现分段错误。

“33790”可能是特定于机器的。我试图理解为什么动态分配的内存会在特定大小后返回段错误。欢迎任何帮助。 :)

#include "iostream"
#include <stdlib.h>
#include "iomanip"
#include "ctime"

#define N 100000

using namespace std;

int main(int argc, char* argv[])
{
    int a;
    cout<<"Size of int : "<<sizeof(int)<<endl;

    long int datasize = strtol(argv[1],NULL,0);
    cout<<"arg1 : "<<datasize<<endl;
    double sum = 0;
    int *data;
    data = new int(datasize);

    clock_t begin = clock();
    for(int i = 0; i < N; i++)                              //repeat the inner loop N times
    {
        //fetch the data into the cache
        //access it multiple times in order to amortize the compulsory miss latency
        for (long int j = 0; j < datasize; j++)
        {
            sum += data[j];                                 //get entire array of data inside cache
        }
    }

    clock_t end = clock();

    double time_spent = (double) (end - begin);

    cout<<"sum = "<<sum<<endl;
    cout<<"Time Spent for data size = "<<argv[1]<<" is "<<time_spent<<endl;

    delete[] data;

    return 0;
}

【问题讨论】:

  • C is not C++ is not C. 不要添加无关标签。

标签: c++ arrays


【解决方案1】:

您没有分配任何数组(具有多个元素),而是仅分配一个具有值 datasizeint

使用new int[datasize] 而不是new int(datasize) 来分配具有datasize 元素的int 数组。

【讨论】:

  • 如果此答案解决了您的问题,请考虑将其标记为正确。
猜你喜欢
  • 1970-01-01
  • 2013-10-03
  • 1970-01-01
  • 1970-01-01
  • 2021-12-09
  • 2013-09-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多