(undo)

如何在 Git 里撤销(几乎)任何操作

大憨熊 提交于 2019-11-30 23:17:41
任何版本控制系统的一个最有的用特性就是“撤销 (undo)”你的错误操作的能力。在 Git 里,“撤销” 蕴含了不少略有差别的功能。 当你进行一次新的提交的时候,Git 会保存你代码库在那个特定时间点的快照;之后,你可以利用 Git 返回到你的项目的一个早期版本。 在本篇博文里,我会讲解某些你需要“撤销”已做出的修改的常见场景,以及利用 Git 进行这些操作的最佳方法。 撤销一个“已公开”的改变 场景: 你已经执行了 git push , 把你的修改发送到了 GitHub,现在你意识到这些 commit 的其中一个是有问题的,你需要撤销那一个 commit. 方法: git revert <SHA> 原理: git revert 会产生一个新的 commit,它和指定 SHA 对应的 commit 是相反的(或者说是反转的)。如果原先的 commit 是“物质”,新的 commit 就是“反物质” — 任何从原先的 commit 里删除的内容会在新的 commit 里被加回去,任何在原先的 commit 里加入的内容会在新的 commit 里被删除。 这是 Git 最安全、最基本的撤销场景,因为它并不会 改变 历史 — 所以你现在可以 git push 新的“反转” commit 来抵消你错误提交的 commit。 修正最后一个 commit 消息 场景: 你在最后一条