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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值