GBD命令小记

 阅读约 2 分钟

GBD

简单的操作命令整理:
编译时加上参数-g,加入调试信息
l,显示代码
l+文件名,显示文件代码
b+行号,加入断点
info break,查看断点信息
clear,清除断点
d+断点编号,清除第n个断点
b+函数名称,在函数插入断点
r,运行程序
c,继续程序
s,单步执行/进入函数
n,逐过程执行
finish,跳出
p+变量名,打印变量
disp+变量名,持续打印变量
bt,函数调用堆栈关系
info threads,线程信息
thread+id,追踪id线程
set follow-fork-mode child,追踪子进程
set follow-fork-mode parent,追踪父进程
ctrl+X ctrl+A 进入一个简单的图形界面

库:预先编译好的方法的集合

静态库

libxxx.a
编译链接跟随程序,编译完成后删除了也可以使用
ar crv libxxx.a aa.o bb.o(c 创建 r 包含方法 v 显示进度)

共享库

libxxx.so
不同的程序均可共享,但是是程序运行中加载,不能删除(一般放在默认路径/usr/lib中)
gcc -shared -fPIC -o libxxx.so aa.o bb.o

-fPIC 作用于编译阶段,告诉编译器产生与位置无关代码(Position-Independent Code),则产生的代码中,没有绝对地址,全部使用相对地址,故而代码可以被加载器加载到内存的任意位置,都可以正确的执行。这正是共享库所要求的,共享库被加载时,在内存的位置不是固定的,如果不加-fPIC,则加载.so文件的代码段时,代码段引用的数据对象需要重定位, 重定位会修改代码段的内容,这就造成每个使用这个.so文件代码段的进程在内核里都会生成这个.so文件代码段的copy.每个copy都不一样,取决于 这个.so文件代码段和数据段内存映射的位置.

使用链接库

gcc -o main main.c -L(库的路径) -l(库名)
//库名是不包含lib以及后面的后缀名的

阅读 346发布于 2018-10-29
推荐阅读
目录