Установка точек останова
Для обнаружения места сбоя в программе необходимо иметь возможность проследить за тем, что делает программа во время выполнения. Остановить ее в любой момент можно с помощью точек останова. Они останавливают программу и передают управление отладчику. Вы сможете проверить переменные и затем разрешить программе продолжить выполнение.
В функции
sort
есть два цикла. Внешний цикл с переменной цикла
i
выполняется для каждого элемента массива один раз. Внутренний или вложенный цикл меняет местами элемент с последующим, расположенным ниже в списке. Это создает эффект всплытия пузырьков, поднимая вверх меньшие элементы. После каждого выполнения внешнего цикла самый большой элемент опускается на дно. Вы можете убедиться в этом, остановив программу на внешнем цикле и просмотрев состояние массива.
Для установки точек останова применяется ряд команд. Их перечень получен отладчиком gdb с помощью команды
help breakpoint
:
(gdb)<b> help breakpoint</b>
Making program stop at certain points.
List of commands:
awatch -- Set a watchpoint for an expression
break -- Set breakpoint at specified line or function
catch -- Set catchpoints to catch events
clear -- Clear breakpoint at specified line or function
commands -- Set commands to be executed when a breakpoint is hit
condition -- Specify breakpoint number N to break only if COND is true
delete -- Delete some breakpoints or auto-display expressions
delete breakpoints -- Delete some breakpoints or auto-display expressions
delete checkpoint -- Delete a fork/checkpoint (experimental)
delete mem -- Delete memory region
delete tracepoints -- Delete specified tracepoints
disable -- Disable some breakpoints
disable breakpoints -- Disable some breakpoints
disable display -- Disable some expressions to be displayed when program stops
disable mem -- Disable memory region
disable tracepoints -- Disable specified tracepoints
enable -- Enable some breakpoints
enable delete -- Enable breakpoints and delete when hit
enable display -- Enable some expressions to be displayed when program stops
enable mem -- Enable memory region
enable once -- Enable breakpoints for one hit
enable tracepoints -- Enable specified tracepoints
hbreak -- Set a hardware assisted breakpoint
ignore -- Set ignore-count of breakpoint number N to COUNT
rbreak -- Set a breakpoint for all functions matching REGEXP
rwatch -- Set a read watchpoint for an expression
tbreak -- Set a temporary breakpoint
tcatch -- Set temporary catchpoints to catch events
thbreak -- Set a temporary hardware assisted breakpoint
watch -- Set a watchpoint for an expression
Type "help" followed by command name for full documentation.
Type "apropos word" to search for commands related to "word".
Command name abbreviations are allowed if unambiguous.
Установите точку останова в строке 21 и выполните программу:
$ <b>gdb debug4</b>
(gdb) <b>break 21</b>
Breakpoint 1 at 0x8048427: file debug4.c, line 21.
(gdb) <b>run</b>
Starting program: /home/neil/BLP4e/chapter10/debug4
Breakpoint 1, sort (a=0x804a040, n=5) at debug4.c:21
21 /* 21 */ s = 0;
Вы можете вывести значение массива и затем с помощью команды
cont
разрешить программе продолжить выполнение. Это позволит программе выполняться до тех пор, пока она не натолкнется на следующую точку останова, в нашем случае это снова строка 21. В любой момент времени может быть активно несколько точек останова:
(gdb)<b> print array[0]</b>
$1 = (data = "bill", '\0' <repeats 4091 times>, key = 3)
Для вывода нескольких последовательных элементов массива можно применить конструкцию
@<<i>число</i>>
, чтобы заставить gdb вывести указанное количество элементов массива. Для того чтобы вывести все пять элементов, можно использовать следующую команду:
(gdb) <b>print array[0]@5</b>
$2 = {{data = "bill", '\0' <repeats 4091 times>, key = 3}, {
data = "neil", '\0' <repeats 4091 times>, key =4}, {
data = "john", '\0' <repeats 4091 times>, key =2}, {
data = "rick", '\0' <repeats 4091 times>, key =5}, {
data = "alex", '\0' <repeats 4091 times>, key = 1}}
Учтите, что вывод немного подчищен, чтобы его легче было читать. Поскольку это первый проход цикла, массив еще не изменен. Когда вы разрешите программе продолжить выполнение, то увидите последовательные перестройки массива array, происходящие по мере выполнения программы:
(gdb) <b>cont</b>
Continuing.
Breakpoint 1, sort (a=0x8049580, n=4) at debug4.c:21
21 /* 21 */ s = 0;
(gdb) <b>print array[0]@5</b>
$3 = {{data = "bill", '\0' <repeats 4091 times>, key = 3}, {