Próbuję debugować program napisany w C++. Oto kod:Funkcja przekroczenia GDB (następna) nie działa.
void a() { }
void b() { a(); }
int main() { b(); return 0; }
Skompilowałem go, używając: g++ -g3 -O0 -o cards.exe cards.cpp
. Oto wynik mojego sesji gdb:
(gdb) b main
Breakpoint 1 at 0x401421: file cards.cpp, line 10.
(gdb) r
Starting program: C:\workspace\Cards\src/cards.exe
[New thread 1624.0xa28]
Breakpoint 1, main() at cards.cpp:10
10 int main()
(gdb) n
12 b();
(gdb) n
b() at cards.cpp:5 5
void b()
(gdb) n
7 a();
(gdb) quit
The program is running. Exit anyway? (y or n)
Moje pytanie brzmi, dlaczego wysłaniem kolejnego polecenia do gdb jeszcze krok do funkcji? Używam g ++ 4.2.1-sjlj i gdb 6.8.
Czy próbowałeś czegoś bardziej złożonego? – stefanB
Właściwie tak, próbuję wykonywanie zapętlonych wywołań do(). Nadal nie będzie działać. Próbowałem również wyłączenie wprowadzania z __attribute __ ((noinline)), ale bezskutecznie. Próbowałem tego na moim Hackintoshu i działało. –