Я пытаюсь скомпилировать программу с отладочными символами, чтобы valgrind дал мне номера строк. Я обнаружил, что если я собираю простую тестовую программу за один раз (с -g), то она содержит символы. Однако, если я скомпилирую за два прохода (т.е. скомпилируем, затем скомпоную), то он не будет содержать символы отладки.
Вот команда компиляции для случая одного прохода:
g++ -g file.c -o file
и за два прохода
g++ -g -c file.c -o file.o
g++ -g file.o -o file
Фактическая программа выглядит следующим образом и содержит простую неверную запись
int main(){
int* x = new int[10];
x[10]=1;
}
Если я компилирую за один проход, тогда valgrind выдаст следующее (запишите номер строки в конце)
==24114== 40 bytes in 1 blocks are definitely lost in loss record 2 of 9
==24114== at 0xB823: malloc (vg_replace_malloc.c:266)
==24114== by 0x5768D: operator new(unsigned long) (in /usr/lib/libstdc++.6.0.9.dylib)
==24114== by 0x576DA: operator new[](unsigned long) (in /usr/lib/libstdc++.6.0.9.dylib)
==24114== by 0x100000F09: main (file.c:3)
тогда как, если я скомпилирую за два прохода, я получу это (без номера строки):
==24135== 40 bytes in 1 blocks are definitely lost in loss record 2 of 9
==24135== at 0xB823: malloc (vg_replace_malloc.c:266)
==24135== by 0x5768D: operator new(unsigned long) (in /usr/lib/libstdc++.6.0.9.dylib)
==24135== by 0x576DA: operator new[](unsigned long) (in /usr/lib/libstdc++.6.0.9.dylib)
==24135== by 0x100000F09: main (in ./file)
Любое понимание этого будет высоко ценится. Я использую gcc версии 4.2.1 на OS X 10.7.3