大家好我是沐曦希💕
文章目录
- 一.预备知识
- 1.背景
- 2.Linux默认行为
- 3.debug和release区别
- 二.使用
- 三.使用git命令行
一.预备知识
1.背景
- 程序的发布方式有两种,debug模式和release模式
- Linux gcc/g++出来的二进制程序,默认是release模式
- 要使用gdb调试,必须在源代码生成二进制程序的时候, 加上 -g 选项
2.Linux默认行为
在Linux中,用gcc/g++生成的软件默认的是release的,不能进行调试。要生成debug模式要加 -g
gcc默认行为:
- 默认动态链接的(生成静态链接要加 -static)
- 默认是release
vim默认行为:默认打开就是命令模式
3.debug和release区别
根据需求不同,程序员需要调试,用户用不到不会用也不关心,用户只需release版本,而程序员关心调试需要debug版本
最明显的区别就是体积不同,debug是大于release的
二.使用
在Linux上调试gdb的思路和其他的调试的思路是一样的,只是调试的方式是不一样的,gdb是用命令行进行调试的。
- 安装
首先要安装调试器gdb
sudo yum install -y gdb
- 默认情况下,gdb无法进行对现在发布的程序进行调试(默认是release版本)
输入gdb进入以下界面:(release下)
不能进行调试
(debug下):改变生成可执行文件的命令:
可以看到debug的体积比release大
gdb进行调试:
**gdb binFile 退出: ctrl + d 或 quit **
- 指令
list/l 行号:显示binFile源代码,接着上次的位置往下列,每次列10行。
list/l 函数名:列出某个函数的源代码。
r或run:运行程序。
n 或 next:单条执行。
s或step:进入函数调用
break(b) 行号:在某一行设置断点
break 函数名:在某个函数开头设置断点
info break :查看断点信息。
finish:执行到当前函数返回,然后停下来等待命令
print§:打印表达式的值,通过表达式可以修改变量的值或者调用函数
p 变量:打印变量值。
set var:修改变量的值
continue(或c):从当前位置开始连续而非单步执行程序
run(或r):从开始连续而非单步执行程序
delete breakpoints:删除所有断点
delete breakpoints n:删除序号为n的断点
disable breakpoints:禁用断点
enable breakpoints:启用断点
info(或i) breakpoints:参看当前设置了哪些断点
display 变量名:跟踪查看一个变量,每次停下来都显示它的值
undisplay:取消对先前设置的那些变量的跟踪
until X行号:跳至X行
breaktrace(或bt):查看各级函数调用及参数
info(i) locals:查看当前栈帧局部变量的值
quit:退出gdb
命令行演示:
- list/l(显示代码)
显示全部代码:
- readelf -S 显示内部格式信息
- b(打断点)
- info b(查看断点)
-
d +断点编号(取消断点)
-
r/run(调试运行,在断点处停下来)
-
n(逐过程) --不会进入函数
-
s(逐语句) --会进入函数
-
c(运行至下一个断点)
-
bt(函数调用堆栈)
-
fin(直接运行到将对于函数跑完)
-
display/undisplay(常显示变量,类似于监视)
-
until(调整至指定行)
-
p 变量:打印变量值,set var:修改变量的值
-
info locals(查看当前栈帧局部变量的值)
-
disable breakpoints:禁用断点
enable也可以关闭断点,并且可以开启断点
上面的指令足够我们现阶段在Linux下使用gdb调试代码了,虽然gdb命令行很难,对于gdb的使用我们应该在后期进行熟练的掌握与使用。
三.使用git命令行
以gitee为例
- 安装git
sudo yum install -y git
- git clone
克隆远程仓库
git clone
在初始配置时候,克隆仓库的http下了后,要输入你的gitee的账号和密码。
完成后:
.gitignore凡事这个文件内部的后缀,都不会被上传到gitee上的。
所谓的git仓库,本质就是一个目录,以及里面的内容。而push到远端就是将.git的内容同步到gitee上
- git add
将新增的文件添加到本地仓库
- git commit
提交。-m 后面加上提交的日志
- git push
将本地内容推送到远端
- git log
查看提交日志
- git status
当远程仓库内容发生变化时: - git pull
把远端拉到本地同步。(如果远端和本地都同步进行修改了,起冲突了,直接先pull一下)
此外,对于git push的时候要输入用户名和密码可以配置成免密码的。不过不推荐。