Git Bisect 使用指南:高效定位引入 Bug 的提交

news/2025/3/21 23:17:43/

git bisect 是一个用来定位引入 bug 的提交的命令。通过二分查找的方式,它能帮助你找到哪一个提交导致了问题,特别是在提交历史较长的情况下非常有用。

使用步骤

  1. 初始化 bisect
    首先,使用 git bisect start 来开始查找。

  2. 标记已知的好提交和坏提交

    • 使用 git bisect good <commit> 来标记一个已知的好提交(没有问题)。
    • 使用 git bisect bad <commit> 来标记当前的坏提交(有问题)。

    例如,假设你知道在 commit A 之前代码是好的,在 commit B 后代码是坏的,命令如下:

    git bisect start
    git bisect good <commit A>
    git bisect bad <commit B>
    
  3. Git 会自动选择一个中间的提交
    Git 会基于你给出的“好”提交和“坏”提交,自动选择一个中间的提交来检查是否存在 bug

  4. 测试并标记每个提交

    • 在每次检查完 Git 选择的提交后,你需要测试代码,看看它是否有 bug
    • 如果提交是好的,使用 git bisect good
    • 如果提交是坏的,使用 git bisect bad
  5. 重复直到找到问题提交
    Git 会继续二分查找,每次选择中间的提交进行检查,直到找到导致问题的提交。

  6. 结束 bisect
    一旦找到了坏提交,使用以下命令结束 bisect:

    git bisect reset
    

    这会将你的 HEAD 恢复到 bisect 开始前的状态。

示例

假设你发现从某个提交开始出现了 bug,但不确定是哪次提交引入的,流程可能如下:

  1. 假设最初的 bug 出现时,当前版本为 bad_commit,之前的版本是好的,可以确定。
  2. 假设从 commit Abad_commit 之间引入了 bug,运行:
    git bisect start
    git bisect good <commit A>  # 标记为好的提交
    git bisect bad <bad_commit>  # 标记为坏的提交
    
  3. Git 会选择一个中间的提交进行测试,测试后,继续使用 git bisect goodgit bisect bad 来标记该提交。
  4. 重复这个过程,直到定位到导致 bug 的提交。

这个方法特别适用于排查问题,特别是当你不确定是哪个提交引入了 bug 时。


http://www.ppmy.cn/news/1581000.html

相关文章

D-Wave专用量子计算机登顶Science 率先展示在真实场景中的量子优势(内附下载)

内容来源&#xff1a;量子前哨&#xff08;ID&#xff1a;Qforepost&#xff09; 文丨浪味仙 排版丨浪味仙 行业动向&#xff1a;4200字丨16分钟阅读 摘要&#xff1a;加拿大专用量子计算机公司 D-Wave 在 Science 期刊发表了论文&#xff0c;题为《Beyond-Classical Compu…

第二:go 链接mysql 数据库

mac  mysql 安装 的步骤 mysql  安装 配制&#xff1a; https://juejin.cn/post/7454870544929472550 mac brew 如何安装mysql数据库 要在Mac上使用Homebrew安装MySQL数据库&#xff0c;请按照以下步骤操作&#xff1a;步骤 1: 安装Homebrew 如果你还没有安装Homebrew&a…

Redis hyperloglog学习

背景知识 【伯努利试验】&#xff1a; 【伯努利试验】是一个概率论中的概念&#xff0c;指在相同的条件下重复进行n次独立的试验&#xff0c;每次试验只有两种可能的结果&#xff0c;且这两种结果发生的概率是固定的 抛硬币作为伯努利试验&#xff1a;在抛硬币时&#xff0c;我…

深入探究 JVM 堆的垃圾回收机制(一)— 判活

垃圾回收分为两步&#xff1a;1&#xff09;判定对象是否存活。2&#xff09;将“消亡”的对象进行内存回收。 1 判定对象存活 可达性分析算法&#xff1a;通过一系列“GC Roots”对象作为起始节点集&#xff0c;从这些节点开始&#xff0c;根据引用关系向下搜索&#xff0c;…

FPGA中级项目3——IP核之时钟管理单元

FPGA中级项目3——IP核之时钟管理单元 时钟还需要管理?什么是时钟管理单元? 我们常熟知FPGA本身有晶振单元,源源不断的提供的50Mhz的频率波。但是这样往往无法满足一些设计需求。使用Verilog代码设计倍频分频等又不可避免的出现毛刺等其他状况,且提升了代码复杂度。因此在 …

CI/CD构建与注意事项

1. CI/CD 概述 1.1 定义 CI&#xff08;Continuous Integration&#xff0c;持续集成&#xff09;&#xff1a;是一种软件开发实践&#xff0c;开发团队成员频繁地将代码集成到共享的代码仓库中。每次集成都会通过自动化的构建&#xff08;包括编译、打包等&#xff09;和测试…

Joker靶机渗透

首先&#xff0c;开启命令行窗口输入ifconfig查看IP地址 端口扫描 nmap nmap 192.168.190.* Kali所属的网段进行全网段扫描&#xff0c;其中*表示通配符0~255。观察开放端口&#xff0c;及对应的不同服务 如果开放的端口有80端口&#xff0c;推测该主机很有可能是一个网站服…

3. 轴指令(omron 机器自动化控制器)——>MC_SetOverride

机器自动化控制器——第三章 轴指令 12 MC_SetOverride变量▶输入变量▶输出变量▶输入输出变量 功能说明▶时序图▶重启运动指令▶多重启动运动指令▶异常 MC_SetOverride 变更轴的目标速度。 指令名称FB/FUN图形表现ST表现MC_SetOverride超调值设定FBMC_SetOverride_instan…