Git-命令

Git branch

Git 的分支非常輕量嚎杨。只是簡單地指向某個提交紀(jì)錄

git checkout -b bugFix
創(chuàng)建一個新的分支并切換到新分支

Git merge

新建一個分支粱挡,在其上開發(fā)某個新功能钮科,開發(fā)完成后再合并回主線


image.png
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)造更線性的提交歷史


image.png
git checkout -b bugFix
git commit -m 'c2'
新建并切換到 新 分支上,且 提交 一次
git checkout main
git commit -m 'c3'
切換回另一并行分支,且提交一次
git checkout bugFix 
git rebase main
再次切換到 新 分支,rebase 到 另一并行分支

HEAD~<num>

image.png
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

image.png

git reset
在reset后,C2 所做的變更還在,但是處于未加入暫存區(qū)狀態(tài),且對 遠(yuǎn)程分支 無效
git revert
新提交記錄 C2' 引入了更改,這些更改剛好是用來撤銷 C2 這個提交的,也就是說 C2' 的狀態(tài)與 C1 是相同的
image.png

git reset HEAD~1
撤銷本地 local 分支 的最近一次提交
git checkout pushed
切換 遠(yuǎn)程分支 pushed
git revert HEAD
撤銷遠(yuǎn)程 pushed 分支的最近一次提交

git cherry-pick <提交號>

image.png
git cherry-pick c3 c4 c7

rebase 交互式

交互式 rebase 指的是使用帶參數(shù) --interactive 的 rebase 命令, 簡寫為 -i


image.png
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 來完成)
合并提交,允許把多個提交記錄合并成一個

提交技巧

image.png
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

image.png
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)>

image.png
git tag v0 c1  //  給c1 加上標(biāo)簽名
git checkout c2  //  切換指向到 c2
git tag v1  //  c2 加上標(biāo)簽名 第二參數(shù)不寫默認(rèn)當(dāng)前指向

Git Describe

image.png

標(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)簽名稱
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末尽爆,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子读慎,更是在濱河造成了極大的恐慌漱贱,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件夭委,死亡現(xiàn)場離奇詭異幅狮,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)株灸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評論 3 385
  • 文/潘曉璐 我一進(jìn)店門崇摄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蚂且,你說我怎么就攤上這事配猫。” “怎么了杏死?”我有些...
    開封第一講書人閱讀 158,369評論 0 348
  • 文/不壞的土叔 我叫張陵泵肄,是天一觀的道長。 經(jīng)常有香客問我淑翼,道長腐巢,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,799評論 1 285
  • 正文 為了忘掉前任玄括,我火速辦了婚禮冯丙,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘遭京。我一直安慰自己胃惜,他們只是感情好泞莉,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,910評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著船殉,像睡著了一般鲫趁。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上利虫,一...
    開封第一講書人閱讀 50,096評論 1 291
  • 那天挨厚,我揣著相機(jī)與錄音,去河邊找鬼糠惫。 笑死疫剃,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的硼讽。 我是一名探鬼主播巢价,決...
    沈念sama閱讀 39,159評論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼理郑!你這毒婦竟也來了蹄溉?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,917評論 0 268
  • 序言:老撾萬榮一對情侶失蹤您炉,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后役电,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體赚爵,經(jīng)...
    沈念sama閱讀 44,360評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,673評論 2 327
  • 正文 我和宋清朗相戀三年法瑟,在試婚紗的時候發(fā)現(xiàn)自己被綠了冀膝。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,814評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡霎挟,死狀恐怖窝剖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情酥夭,我是刑警寧澤赐纱,帶...
    沈念sama閱讀 34,509評論 4 334
  • 正文 年R本政府宣布,位于F島的核電站熬北,受9級特大地震影響疙描,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜讶隐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,156評論 3 317
  • 文/蒙蒙 一起胰、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧巫延,春花似錦效五、人聲如沸地消。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽脉执。三九已至,卻和暖如春瓜客,著一層夾襖步出監(jiān)牢的瞬間适瓦,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評論 1 267
  • 我被黑心中介騙來泰國打工谱仪, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留玻熙,地道東北人。 一個月前我還...
    沈念sama閱讀 46,641評論 2 362
  • 正文 我出身青樓疯攒,卻偏偏與公主長得像嗦随,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子敬尺,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,728評論 2 351

推薦閱讀更多精彩內(nèi)容