Литмир - Электронная Библиотека
Содержание  
A
A

Установка точек останова

Для обнаружения места сбоя в программе необходимо иметь возможность проследить за тем, что делает программа во время выполнения. Остановить ее в любой момент можно с помощью точек останова. Они останавливают программу и передают управление отладчику. Вы сможете проверить переменные и затем разрешить программе продолжить выполнение.

В функции

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 &quot;help&quot; followed by command name for full documentation.

Type &quot;apropos word&quot; to search for commands related to &quot;word&quot;.

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 = &quot;bill&quot;, '\0' &lt;repeats 4091 times&gt;, key = 3)

Для вывода нескольких последовательных элементов массива можно применить конструкцию

@&lt;<i>число</i>&gt;
, чтобы заставить gdb вывести указанное количество элементов массива. Для того чтобы вывести все пять элементов, можно использовать следующую команду:

(gdb) <b>print array[0]@5</b>

$2 = {{data = &quot;bill&quot;, '\0' &lt;repeats 4091 times&gt;, key = 3}, {

    data = &quot;neil&quot;, '\0' &lt;repeats 4091 times&gt;, key =4}, {

    data = &quot;john&quot;, '\0' &lt;repeats 4091 times&gt;, key =2}, {

    data = &quot;rick&quot;, '\0' &lt;repeats 4091 times&gt;, key =5}, {

    data = &quot;alex&quot;, '\0' &lt;repeats 4091 times&gt;, 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 = &quot;bill&quot;, '\0' &lt;repeats 4091 times&gt;, key = 3}, {

190
{"b":"285844","o":1}