git bisect 二分查找定位错误
# git bisect 二分查找指南 ## 1. 基本原理(ascii示意图) 假设提交历史是一条时间线,g=good(正常),b=bad(异常):
提交顺序: g --- g --- g --- b --- b --- b | | | 初始正常 首次出错 当前异常
git bisect 会通过二分法快速定位中间的 b。 ## 2. 完整操作流程 ### 步骤1:启动并标记范围 ```bash # 启动二分查找 git bisect start # 标记当前提交为异常(bad) git bisect bad # 标记已知正常的旧提交(例如1周前的版本) git bisect good a1b2c3d
git会自动计算出中间提交并检出到工作区。
测试中间提交
检查当前代码状态:
- 如果正常:
git bisect good
git会继续在后半部分查找(提交4-6)。
- 如果异常:
git bisect bad
git会继续在前半部分查找(提交1-3)。
重复直到定位
最终git会输出:
abcdef1 is the first bad commit
commit abcdef1
author: xxx
date: xxx
错误提交的描述...
自动化测试(高级用法)
编写测试脚本(如 test.sh):
#!/bin/sh # 测试通过返回0,失败返回1 npm test
运行自动化测试:
git bisect run ./test.sh
关键点总结
- 适用场景:适合代码历史较长(如100+提交)的问题定位
- 效率:1000次提交仅需约10次测试(2^10=1024)
注意事项:
- 确保测试结果准确
- 结束后务必执行
git bisect reset
- 测试脚本应具有明确的状态返回值
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
发表评论