While debugging an executable using gdb, there are two commands which we can use to step through the execution:
stepi
andnexti
What is/are the difference/s between these two and why would anyone choose one over the other?
using help in gdb says:
stepi: Step one instruction exactly.
nexti: Step one instruction, but proceed through subroutine calls.
since we are dealing with instructions and machine code here (the smallest part of a program in execution) I can't figure out what the subroutine calls are.
stepi
is more detailed than nexti
. if you call sum()
from main()
function then doing stepi
reaches you inside the sum() function, but nexti
doesn't.
Below is the screenshot when you call stepi
when you were at call of sum() instruction (i.e., => 0x08048403 <+40>: call 0x8048419 <sum>
). The stepi
instuction routes you inside the sum()
.
If you do nexti
when you were at call of sum() instruction (i.e., => 0x08048403 <+40>: call 0x8048419 <sum>
) then it uses the returned value from sum method and goes to the next instruction of main method, screenshot as below.
Conclusion: Use stepi
if you want to see every machine instructions that happened in your processor. Use nexti
if you wanna see only the machine instructions executed at the main()
.