Git 自救指南
发布日期:2021-05-09 01:42:35 浏览次数:22 分类:博客文章

本文共 1262 字,大约阅读时间需要 4 分钟。

Git 虽然因其分布式管理方式,不完全依赖网络,良好的分支策略,容易部署等优点,已经成为最受欢迎的源代码管理方式。但是一分耕耘一分收获,如果想更好地掌握 git,需要付出大量的学习成本。即使在各种 GUI 的加持下,也不得不说 git 真的很难,在 V2EX 上也常有如何正确使用 git 的讨论,同时在 Stackoverflow 上超过 10w+ 的 git 相关问题也证明了 git 的复杂性。再加上 git 的官方文档也一直存在着 “先有鸡还是先有蛋” 的问题,虽然文档非常全面,但如果你不知道你遇到的问题叫什么,那么根本就无从查起。

作为国内领先的研发管理解决方案供应商,CODING 一直致力于在国内普及 git 的使用,为软件研发提供更高效率。本文节选自 Katie Sylor-Miller 在日常工作中所遇到过的让他很头疼的 git 相关问题,并整理了相应的应对措施,在这里分享给正在学习如何使用 git 的同学们。当然这些应对措施并不是唯一的,可能你会有其他更好的应对方法,这也恰恰是 git 这套版本控制系统强大的地方。

原文标题:《Oh shit,git!》

原文地址:

我刚刚好像搞错了一个很重要的东西,但是 git 有个神奇的时间机器能帮我复原!

reflog 是一个非常实用的命令,你可以使用这个命令去找回无意间删除的代码,或者去掉一些刚刚添加的却把仓库里的代码弄坏的内容。同时也可以拯救一下失败的 merge,或者仅仅是为了回退到之前的版本。

我 commit 完才想起来还有一处小地方要修改!

当我 commit 完然后跑测试的时候,经常突然发现忘了在等于号前面加空格。虽然可以把修改过的代码再重新 commit 一下,然后 rebase -i 将两次揉在一起,不过上面的方法会比较快。

我要改一下上一个 commit message!

当你们组对 commit message 有格式要求时,或者当你忘了中英文间要加空格,这个命令能救你狗命。

我不小心把本应在新分支上的内容 commit 到 master 了!

注意:这个指令必须在错误的 commit 后直接执行,如果你已经试了其他的方式,你可能就需要用 git reset HEAD@{number} 来代替 HEAD~ 了。

我不小心 commit 到错误的分支上了!

也有很多人推荐了 cherry-pick 的解决方案,所以选哪个就看你心情了。

我执行了 diff 但是啥也没出现

Git 不会给通过 add 加入到 staging 区域里面的文件做 diff ,除非你加了 --staged 的标签,别怀疑了这是一个 feature 不是一个 bug,当然对于第一次碰到这个问题的人来说还是有些不好理解的。

Git 从入门到放弃

为了维护最后的尊严 XD

不知道你在使用 git 中有没有遇到过各种令人掀桌的问题呢?

或者作为 git 资深用户有什么可以分享的小技巧呢?

欢迎大家在留言区跟我们互动~

点击 ,体验敏捷研发!

上一篇:CODING 受邀参与 DevOps 标准体系之系统和工具&技术运营标准技术专家研讨会
下一篇:CODING 受邀参加《腾讯全球数字生态大会》

发表评论

最新留言

能坚持,总会有不一样的收获!
[***.219.124.196]2025年04月28日 19时58分37秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

#C8# UVM中的factory机制 #S8.1.2# 到底重载?多态? 2023-01-23
#C8# UVM中的factory机制 #S8.1.3# UVM实战代码再剖析 2023-01-23
#C8# UVM中的factory机制 #S8.1.4# 约束的重载 2023-01-23
#C8# UVM中的factory机制 #S8.2.1# factory 机制重载法则 2023-01-24
#systemverilog# 之 event region 和 timeslot 仿真调度(三)概念 2023-01-24
#C8# UVM中的factory机制 #S8.2.2# 复杂重载方式 2023-01-24
#C8# UVM中的factory机制 #S8.2.3# 重载sequence哪些情形 2023-01-24
#C8# UVM中的factory机制 #S8.4.1# factory机制的实现 2023-01-24
#C8# UVM中的factory机制 #S8.4.3# factory机制创建实例接口 2023-01-24
#C8# UVM中的factory机制 #S8.5# 对factory机制的重载进一步思考 2023-01-24
#Day Day Plan# 《NCB_PCI_Express_Base 5.0.1.0》pdf 译文笔记 模版 2023-01-24
#Linux# Linux系统下如何查看磁盘空间占据情况 2023-01-24
#Linux杂记# grep 查找命令常用选项大全(一) 2023-01-24
#Linux杂记# grep 查找命令常用选项大全(二) 2023-01-24
.exe已停止工作_windows资源管理器已停止工作怎么解决 2023-01-24
7 自动开启网卡_软件测试学习教程——CentOS 7 修改网卡设置 2023-01-24
8位二进制转bcd算法 c语言,二进制转BCD码快速算法 bin to bcd fast code. 2023-01-24
900行c语言贪吃蛇,原生js实现的贪吃蛇网页版游戏完整实例 2023-01-24
ado filter 多条记录_Excel 有了Filter函数VLOOKUP函数要靠边站了 2023-01-24
ado读取多条oracle数据,Oracle ADO数据存取 2023-01-24