【问题标题】:Program received Segmentation fault while debug in CLion在 CLion 中调试时程序收到分段错误
【发布时间】:2019-11-27 12:51:29
【问题描述】:

我面临实施单纯形法(或单纯形算法)的挑战。单纯形法是一种流行的线性规划算法,它基于重建矩阵。我的程序应该返回一个最佳解决方案。我在 Clion 有一个 C++ 项目。当我运行程序时它可以正常工作,但是在调试期间,我在其中一种方法中得到了一个 SIGSEGV 信号(分段错误)。当我尝试为矩阵分配内存时会发生这种情况。以下是部分代码:

double **newTable;
    newTable = new double *[rows];
    for (int i = 0; i < rows; ++i) {
        for (int j = 0; j < cols; ++j) {
            newTable[i] = new double [cols];
        }
    }

我在方法结束时使用 delete[] 释放了内存,但它不起作用。 我已经尝试在另一个 IDE(CodeBlocks)中运行该程序,但它也可以正常工作,我不知道它为什么会发生以及问题发生在哪里。

【问题讨论】:

  • 您展示的代码存在大量内存泄漏,但没有任何可能导致崩溃的情况。如果您在 CLion 中使用了调试器,它会在代码中的哪个位置告诉您崩溃发生了?
  • 当我运行程序时它可以正常工作,但是在调试过程中,我在其中一种方法中收到了 SIGSEGV 信号(分段错误)。 -- 这意味着它没有不能正常工作。另外,我们不知道这段代码在哪里、何时或如何被调用,我们不知道rowscols 等的值。请发minimal reproducible example
  • 我实际上在分配的调试模式下也遇到了 clion 崩溃。尝试。从命令行调试。如果它有效(它对我有用)它的 clion。

标签: c++ debugging segmentation-fault clion


【解决方案1】:

不需要这个嵌套循环。你只需要一个循环来为这个锯齿状数组分配内存:

int main() {
    int rows = 5, cols = 10;
    double **newTable;
    newTable = new double *[rows];
    for (int i = 0; i < rows; ++i) 
        newTable[i] = new double[cols];

    for (int i = 0; i < rows; ++i)
        delete newTable[i];
    delete newTable;
}

您的代码现在的方式会泄漏内存,但仅此一项不会导致分段错误。您释放内存的方式也可能存在错误。


另外,由于这是 C++,我可以推荐使用 std::vector 代替吗?

#include <vector>
int main() {
    std::vector<std::vector<double>> newTable(5, std::vector<double>(10));
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2019-01-27
    • 1970-01-01
    • 2015-09-15
    • 2020-01-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多