以下代码中的错误是memcpy(t[j], m[j], sizeof(int) * DIM * DIM);
应为memcpy(t[j], m[j], sizeof(int) * DIM);
:
// Untitled7.c
#include <stdio.h>
#include <string.h>
#define DIM 1000
int main(void)
{
int m[DIM][DIM], t[DIM][DIM];
unsigned j, k;
for(j = 0; j < DIM; j++)
for(k = 0; k < DIM; k++)
m[j][k] = j * DIM + k;
for(j = 0; j < DIM; j++)
memcpy(t[j] ,m[j], sizeof(int) * DIM * DIM); // only one DIM
for(j = 0; j < DIM; j++)
for(k = 0; k < DIM; k++)
m[j][k] = t[DIM-k-1][j];
return 0;
}
使用gdb我怎么能找到那个错误?我了解了如何创建核心文件(使用ulimit -c unlimited
),然后我使用了$ gdb Untitled7 core
,它给出了:
...
Reading symbols from Untitled7...done.
[New LWP 10610]
Core was generated by ` ? @ A'. // and symbols of binary files
Program terminated with signal SIGSEGV, Segmentation fault.
#0 __memcpy_ssse3 () at ../sysdeps/i386/i686/multiarch/memcpy-ssse3.S:2590
2590 ../sysdeps/i386/i686/multiarch/memcpy-ssse3.S: File o directory non esistente. // File or directory not existent.
我该怎么办?
答案 0 :(得分:0)
您无法始终以这种方式找到真正的错误,但您可以找到发生细分违规的位置。
您需要使用调试信息编译程序,最好不要进行优化,即使用-ggdb -O0
编译标志。如果违规位于库函数内部(如您的示例中所示),请使用gdb
命令up
向上移动调用堆栈,直到您到达代码。然后,您应该看到该程序的违规行。
确保gdb
可以找到您的来源。通常,当您的当前目录是构建目录时,gdb
可以找到它们。如果没有,请使用directory
的{{1}}命令。