在 CLion 中调试时程序收到分段错误
Program received Segmentation fault while debug in CLion
我面临实施单纯形法(或单纯形算法)的挑战。单纯形法是一种流行的线性规划算法,它基于重建矩阵。我的程序应该 return 一个最优解。我在 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) 中的程序,但它也能正常工作,我不知道它为什么会发生以及问题发生在哪里。
不需要这个嵌套循环。你只需要一个循环来为这个锯齿状的数组分配内存:
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));
}
我面临实施单纯形法(或单纯形算法)的挑战。单纯形法是一种流行的线性规划算法,它基于重建矩阵。我的程序应该 return 一个最优解。我在 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) 中的程序,但它也能正常工作,我不知道它为什么会发生以及问题发生在哪里。
不需要这个嵌套循环。你只需要一个循环来为这个锯齿状的数组分配内存:
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));
}