准备工作
目录结构如下
.
├── insert_sort.c
├── main.c
├── my_sort.h
insert_sort.c
void insert(int arr[], int len) {
int i, j, key;
for (i = 1; i < len; i++) {
key = arr[i];
j = i - 1;
while ((j >= 0) && (arr[j] > key)) {
arr[j + 1] = arr[j];
j--;
}
arr[j + 1] = key;
}
}
my_sort.h
void insert(int arr[], int len);
main.c
#include <stdio.h>
#include "my_sort.h"
void main() {
int arr[] = {1, 10, 20, 39, 5, 9, 88};
int len = sizeof(arr) / sizeof(int);
printf("sort before\n");
for (int i = 0; i < len; i++) {
printf("%d ", arr[i]);
}
printf("\n");
insert(arr, len);
printf("sort after\n");
for (int i = 0; i < len; i++) {
printf("%d ", arr[i]);
}
printf("\n");
}
编译
$ gcc *.c -o test1 -g
$ gcc *.c -o test2
$ ls test* -al
-rwxr-xr-x 1 root root 10480 Dec 17 09:25 test1
-rwxr-xr-x 1 root root 8840 Dec 17 09:25 test2
能看出test1明显大,一般发行版本为Release,Debug为调试版本。
gdb命令
$ gdb test1
命令 | 举例 | 全称 | 作用 |
---|---|---|---|
l | - | list | 查看源码,默认十行 |
l | l insert_sort.c:5 | - | 查看指定insert_sort.c文件的第5行,默认显示10行 |
l | l insert_sort.c:insert | - | 查看指定insert_sort.c文件的函数 |
b | b 10 | break | 给第10行打断点 |
b | b 8 if i==3 | - | 条件断点,如果第8行的i等于3就中断 |
i | i b | info break | 查看所有断点信息,编号信息 |
r | r | run | 开始运行,直到断点处停止 |
start | start | - | 开始运行,以step运行 |
n | n | next | 单步执行 |
c | c | continue | 继续执行,直到下一个断点 |
s | s | step | 进入到函数内部 |
p | p i | print i | 输出i的值 |
ptype | ptype i | - | 查看i的类型 |
display | display i | - | 追踪变量i的值,类似IDE的watch |
undisplay | undisplay 2 | - | 删除追踪,info display查看编号 |
u | u | util | 跳出循环 |
finish | finish | - | 跳出当前进入的函数 |
d | d 2 | delete | 删除编号为2的断点,i b查看断点编号 |
set | set var i=10 | - | 将变量i设置为10 |
q | quit | quit | 退出gdb |
补充
set follow-fork-mode child 在fork之后跟踪子进程
set follow-fork-mode parent 跟踪父进程