Git branch
Git 的分支非常輕量嚎杨。只是簡單地指向某個提交紀(jì)錄
git checkout -b bugFix
創(chuàng)建一個新的分支并切換到新分支
Git merge
新建一個分支粱挡,在其上開發(fā)某個新功能钮科,開發(fā)完成后再合并回主線
git checkout -b bugFix
git commit -m 'c2'
新建并切換到新分支上,且 提交 一次
git checkout main
git commit -m 'c3'
切換回 并行分支,且 提交 一次
git merge bugFix
把 bugFix 分支合并到 main 分支
Git Rebase
第二種合并分支的方法是 git rebase退盯。Rebase 實際上就是取出一系列的提交記錄裤园,“復(fù)制”它們撤师,然后在另外一個地方逐個的放下去
Rebase 的優(yōu)勢就是可以創(chuàng)造更線性的提交歷史
git checkout -b bugFix
git commit -m 'c2'
新建并切換到 新 分支上,且 提交 一次
git checkout main
git commit -m 'c3'
切換回另一并行分支,且提交一次
git checkout bugFix
git rebase main
再次切換到 新 分支,rebase 到 另一并行分支
HEAD~<num>
git checkout '哈希' // 改變 HEAD 指向
git checkout HEAD^ // 相對引用(^)
使用 ^ 向上移動 1 個提交記錄
使用 ~<num> 向上移動多個提交記錄,如 ~3
git branch -f <分支> HEAD~<num>
將 分支 強(qiáng)制指向 HEAD 的第 <num> 級父提交
git branch -f main c6
git branch -f bugFix c0
git checkout HEAD~1
想看 HEAD 指向拧揽,可以通過 cat .git/HEAD 查看剃盾, 如果 HEAD 指向的是一個引用,還可以用 git symbolic-ref HEAD 查看它的指向淤袜。但是該程序不支持這兩個命令)
git reset git revert
git reset
在reset后,C2 所做的變更還在,但是處于未加入暫存區(qū)狀態(tài),且對 遠(yuǎn)程分支 無效
git revert
新提交記錄 C2' 引入了更改,這些更改剛好是用來撤銷 C2 這個提交的,也就是說 C2' 的狀態(tài)與 C1 是相同的
git reset HEAD~1
撤銷本地 local 分支 的最近一次提交
git checkout pushed
切換 遠(yuǎn)程分支 pushed
git revert HEAD
撤銷遠(yuǎn)程 pushed 分支的最近一次提交
git cherry-pick <提交號>
git cherry-pick c3 c4 c7
rebase 交互式
交互式 rebase 指的是使用帶參數(shù) --interactive 的 rebase 命令, 簡寫為 -i
git rebase -i HEAD~4
'pick:保留該commit(縮寫:p)
reword:保留該commit痒谴,但我需要修改該commit的注釋(縮寫:r)
edit:保留該commit, 但我要停下來修改該提交(不僅僅修改注釋)(縮寫:e)
squash:將該commit和前一個commit合并(縮寫:s)
fixup:將該commit和前一個commit合并,但我不要保留該提交的注釋信息(縮寫:f)
exec:執(zhí)行shell命令(縮寫:x)
drop:我要丟棄該commit(縮寫:d)
--onto的意思是要將該指定的提交復(fù)制到哪個分支上'
rebase 界面能做3件事:
調(diào)整提交記錄的順序
刪除你不想要的提交(通過 pick 來完成)
合并提交,允許把多個提交記錄合并成一個
提交技巧
git rebase -i HEAD~2 // 交換C2和C3的位置
git commit --amend // 當(dāng)前結(jié)點(diǎn)的父結(jié)點(diǎn)再分出一個修改后的子結(jié)點(diǎn)
git rebase -i HEAD~2 // 調(diào)回順序
git checkout main // 將當(dāng)前分支切回 主分支
git rebase <合并分支>
提交技巧 git cherry-pick
git checkout main // 切換到主分支
git cherry-pick newImage // 將C2接到C1后面
git commit --amend // 創(chuàng)造新結(jié)點(diǎn)C2''
git cherry-pick caption // 將C3加至C2''后面
git tag <標(biāo)簽名> <提交點(diǎn)>
git tag v0 c1 // 給c1 加上標(biāo)簽名
git checkout c2 // 切換指向到 c2
git tag v1 // c2 加上標(biāo)簽名 第二參數(shù)不寫默認(rèn)當(dāng)前指向
Git Describe
標(biāo)簽在代碼庫中起著“錨點(diǎn)”的作用,git describe用來描述離你最近的錨點(diǎn)
git describe <ref> // 任何能被 Git 識別成提交記錄的引用,默認(rèn)為當(dāng)前 <HEAD>
輸出的結(jié)果是這樣的:
<tag>_<numCommits>_g<hash>
tag 表示的是離 ref 最近的標(biāo)簽铡羡, numCommits 是表示這個 ref 與 tag 相差有多少個提交記錄积蔚, hash 表示的是你所給定的 ref 所表示的提交記錄哈希值的前幾位。
當(dāng) ref 提交記錄上有某個標(biāo)簽時烦周,則只輸出標(biāo)簽名稱