1、.gdbinit 文件是什么:
gdb在启动的时候,会在你的当前工作目录下查找
".gdbinit"
这个文件,并把它的内容作为gdb命令进行解释,所以如果我把脚本命名为".gdbinit",这样在启动的时候就会处理一些你常用的命令。
注意:这里当前工作目录是提示 ~
的目录,一般是/home/xxx。
如何查看该目录:
1、cd ~
切到当前工作目录
2、pwd
查看该目录的路径
实际使用时,会存在一个问题,比如你需要在 D:/worksapce下Debug, 因此,你想在 D:/worksapce 下添加
.gdbinit
方便调试。
这个时候如果直接 D:/worksapce 下添加.gdbinit
, 然后调用GDB
会报如下错误:
auto-loading has been declined by your `auto-load safe-path' set to "$debugdir:$datadir/auto-load".
怎么办?
解决办法如下:
1、在/home/xxxx
下添加一个.gdbinit
, 默认GDB初始化时会调用这个文件。
2、编辑该.gdbinit
, 加上 set auto-load safe-path /
set auto-load safe-path D:/workspace/
3、在D:/workspace/
(即你要Debug的目录)下,同样添加一个.gdbinit
4、编辑该.gdbinit
,添加你需要的一些指令,例如:
set style address foreground red //将地址的颜色改成红色
# 保存历史命令
set history filename ./.gdb_history
set history save on
# 记录执行gdb的过程
set logging file ./.log.txt
set logging on
# 退出时不显示提示信息
#set confirm off
# 打印数组的索引下标
set print array-indexes on
# 每行打印一个结构体成员
set print pretty on
此外GDB还支持自定义,语法结构遵循如下基本格式:
define <command>
<code>
end
document <command>
<help text>
end
该命令称为用户命令。可以将所有其他标准 GDB 命令与流控制指令结合使用并向其传递参数,从而创建一种语言,以允许为正在调试的特定应用程序而自定义调试器的行为。
# 退出并保留断点
define qbp
save breakpoints ./.gdb_bp
quit
end
document qbp
Exit and save the breakpoint
end
# 保留历史工作断点
define downbp
save breakpoints ./.gdb_bp
end
document downbp
Save the historical work breakpoint
end
# 加载历史工作断点
define loadbp
source ./.gdb_bp
end
document loadbp
Load the historical work breakpoint
end