


當嘗試合并這些分支時,Git 會向你展示沖突出現的位置。我們可以手動移除我們不想保留的修改,保存這些修改,再次添加這個已修改的文件,然后提交這些修改。


在我們正在 rebase 的提交上,我們可以執行以下 6 個動作:
-
reword:修改提交信息;
-
edit:修改此提交;
-
squash:將提交融合到前一個提交中;
-
fixup:將提交融合到前一個提交中,不保留該提交的日志消息;
-
exec:在每個提交上運行我們想要 rebase 的命令;
-
drop:移除該提交。


當我們不想要之前提交的修改時,就會用到這個命令。也許這是一個 WIP 提交或者可能是引入了 bug 的提交,這時候就要執行 git reset。
git reset 能讓我們不再使用當前臺面上的文件,讓我們可以控制 HEAD 應該指向的位置。
軟重置
軟重置會將 HEAD 移至指定的提交(或與 HEAD 相比的提交的索引),而不會移除該提交之后加入的修改!
假設我們不想保留添加了一個 style.css 文件的提交 9e78i,而且我們也不想保留添加了一個 index.js 文件的提交 035cc。但是,我們確實又想要保留新添加的 style.css 和 index.js 文件!這是軟重置的一個完美用例。

有時候我們并不想保留特定提交引入的修改。不同于軟重置,我們應該再也無需訪問它們。Git 應該直接將整體狀態直接重置到特定提交之前的狀態:這甚至包括你在工作目錄中和暫存文件上的修改。

假設 ec5be 添加了一個 index.js 文件。但之后我們發現其實我們再也不需要由這個提交引入的修改了。那就還原 ec5be 提交吧!


通過在這個遠程分支上執行 git fetch,我們就可在本地獲取這些修改。這不會以任何方式影響你的本地分支:fetch 只是單純地下載新的數據而已。


git reflog 是一個非常有用的命令,可以展示已經執行過的所有動作的日志。包括合并、重置、還原,基本上包含你對你的分支所做的任何修改。

假設我們實際上并不需要合并原有分支。當我們執行 git reflog 命令時,我們可以看到這個 repo 的狀態在合并前位于 HEAD@{1}。那我們就執行一次 git reset,將 HEAD 重新指向在 HEAD@{1} 的位置。

? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END