版本控制器Git/调试器gdb/cgdb使用

一Git

1、如何理解版本控制---->Git && gitee/github

2、Git历史 开源的

git 是一个client,也是一个server是一个底层的版本控制器软件

去中心化,分布式的版本控制

3、Git操作

git提交的时候,只会提交变化的部分!

此时的test.c还没有被仓库管理起来

由此可见,"" 不能胡写,git log一下,直接裸在面试官面前了

最后一步,同步

1、git命令的安装

git yum install git

git --version(查)

2、git 版本管理,只进行管理源文件

如果首次使用git

3、.gitignore需要忽略的特定后缀文件列表(过滤)

4、远端仓库,相比较于任何人,都是最新的

为什么要冲突?

提醒本地用户,你要和远端仓库进行同步了

二、gdb/cgdb使用

模式:1>debug

2>release---->测试----->上线

Linux下我们编好的代码,无法调试

gcc/g++:默认的工作模式是release模式

-g:让最后形成可执行程序,添加调试信息-dubug模式

程序调试,必须是dugug模式,也就是编译时要加-g,gdb携带调试信息的exe

1、快速认识gdb

gdb bin

quit 退出

2、gdb命令的学习

b 加行号 打断点

info 查断点

d 根据编号删,不能输行号

r 运行程序

gdb 不退出,断点编号依次递增

f10:逐过程 ------->next/n

f11:逐语句 ---------->step/s

gdb会自动记录最新的一条输入指令

bt 打印当前线程的函数调用栈

p 变量 打印指定变量的值

断点可以被、使能

finish 执行当前函数返回,然后停止

disable n 禁用断点

enable n 启用断点

调试的本质:1,找到问题----找命令

2,查看代码上下文

解决问题

断点的本质是把代码进行块级别划分,以块为单位进行快速定位区域

finish 确认问题是否在函数内

until 局部区域快速执行 until n 到某行

调式技巧

1>watch

注: 如果有一些变量不应该修改,但是你怀疑它修改导致了问题,可以watch,如果变化了,就会通知你

2>set var

更改一下标志位

3> 条件断点

b 13 if i == 10

注:1>新增2>给已有断点追加

新增:b 行号/文件名:行号/函数名 条件 if i==30

给已有断点追加:condition 2 i ==30,其中2是已有断点编号,没有if

cgdb分屏操作 ,esc进入代码屏,i回到gdb屏

相关推荐
摇滚侠23 分钟前
创建 git 忽略文件 忽略 .obsidian 这个目录
大数据·git·elasticsearch
studytosky35 分钟前
【高并发内存池】线程缓存核心原理与实现
linux·服务器·git·缓存
咕咕嘎嘎10241 小时前
问卷系统测试报告
git
水无痕simon2 小时前
04 Git基础-记录每次更新到仓
git
无限进步_2 小时前
【C++】寻找数组中出现次数超过一半的数字:三种解法深度剖析
开发语言·c++·git·算法·leetcode·github·visual studio
一个程序猿老马14 小时前
012、远程协作:连接GitHub/Gitee与git remote
git·gitee·github
Lisonseekpan17 小时前
Git:如何将一个分支的特定提交合并到另一个分支?
java·大数据·git·后端·elasticsearch
pas13619 小时前
git 配置
git
独隅1 天前
Git误操作急救手册
大数据·git·elasticsearch
水无痕simon1 天前
03 Git 工作流程
git