GBD命令小记

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以及后面的后缀名的内存

相关文章
相关标签/搜索