溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Git機(jī)制的知識點(diǎn)有哪些

發(fā)布時間:2021-11-15 16:16:59 來源:億速云 閱讀:123 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容主要講解“Git機(jī)制的知識點(diǎn)有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Git機(jī)制的知識點(diǎn)有哪些”吧!

一、兩次的 git commit 到不是同一個遠(yuǎn)程分支

Git機(jī)制的知識點(diǎn)有哪些

  • 這里由于提交自己的代碼第一次提交到A分支,第二次提交B分支,然后報錯了,這里報錯以后,會提示一個百度自己內(nèi)部的鏈接,你點(diǎn)擊鏈接就可以照著提示去修改,可以說還是省了不少事,不用自己去google百度去解決,開發(fā)效率也提高不少

  • 上面圖片中有6e8713f is CR parent commit 這行提示,劃重點(diǎn),待會要用到。

解決過程

你當(dāng)前的操作場景如下圖,由于一次CR(評審)的多個commits不能push到不同的refs/for/[分支名](可能導(dǎo)致后續(xù)評審合入merge failed):

Git機(jī)制的知識點(diǎn)有哪些

>評審是啥意思,這里解釋一下。本地開發(fā)的流程首先是從自己遠(yuǎn)程的分支A拉到本地,遠(yuǎn)程分支是master分支的一個clone,本地完成開發(fā)后,需要提交到自己的遠(yuǎn)程分支,提交以后必須由其它人評審代碼(code reviewe),其它同事評審的時候主要找出不合規(guī)范和邏輯的地方,你需要修改完成以后,才能合入到你的遠(yuǎn)程分支A,然后再從你的遠(yuǎn)程分支A合到master上,這樣就完成了代碼入庫。

  • 本次合并我最終的目的是要合到B分支(第一次提交是A分支,第二次是B分支)

  • 如果你期望commit 1和commit 2均合入分支B:

  • 請回滾本地commit,重新合并為同一筆commit push至分支 B (會生成一筆新的評審)

操作命令

$git reset --soft [CR parent commit] (對應(yīng)CR parent commit見push報錯信息.也就是有6e8713f is CR parent commit)   
$git commit -m"commit message"   
$git push origin HEAD:refs/for/[branch B]

二、git 撤銷文件修改

什么時候用到

  • 如果有文件A沒有發(fā)生修改,但是再提交評審的時候還是發(fā)現(xiàn)A出現(xiàn)了修改,你使用git diff 并沒有發(fā)現(xiàn)你的本地文件A和遠(yuǎn)程分支A有什么不同,需要撤銷修改

  • 不小心勿加了空行

  • 就是想撤銷已經(jīng)提交的某個文件的修改

如何操作

Git機(jī)制的知識點(diǎn)有哪些

1. 撤銷緩存區(qū)的修改

git reset HEAD filename
  1. 撤銷工作區(qū)的修改

git checkout --filename

三、git 沖突解決

Git機(jī)制的知識點(diǎn)有哪些 上圖是提交代碼時候,發(fā)生了沖突,依舊很貼心,百度這套代碼審查系統(tǒng)依舊給了提示,照著提示操作一波。

Step1. 在本地倉庫中, 更新并合并代碼

git fetch origin
git rebase origin/master

Step2. 依據(jù)提示分別打開沖突的文件,逐一修改沖突代碼

  • Git機(jī)制的知識點(diǎn)有哪些

  • Git機(jī)制的知識點(diǎn)有哪些

  • 可以看到有head和你的本次提交信息,head是遠(yuǎn)程分支,git commit -m "commit提交信息" 這條命令中我填的是689任務(wù),可以看到每有一處信息不一致,在你產(chǎn)生沖突的文件都會提示出來。

  • 我們需要做的就是解決沖突,對比遠(yuǎn)程和你本地產(chǎn)生沖突的地方,保留下你需要的代碼,同時記得把head和689任務(wù)(commit提交信息)這些不是代碼中的內(nèi)容刪除掉。

  • 或者不需要這樣一點(diǎn)點(diǎn)修改,你已經(jīng)知道了你需要提交什么樣的代碼,那么直接將你確定好沒問題的代碼復(fù)制到這份沖突文件中,然后進(jìn)行g(shù)it三連即可

Step3. 所有沖突都修改完畢后, 提交修改的代碼

git add -u
git rebase --continue

Step4. 更新patch

git push origin HEAD:refs/for/master

四、撤銷你的commit提交

如何撤銷commit提交,熟練的執(zhí)行完以下兩條命令以后:

git add *
git commit -m "提示信息A"

你發(fā)現(xiàn)自己的提示信息寫的不對,想git commit -m "提示信息B",但是由于已經(jīng)git commit 過了,會提示你沒有什么需要git commit的,這個時候如何撤銷git commit呢?

git reset --soft HEAD^

這樣上一次提交就被撤回了,然后繼續(xù)執(zhí)行g(shù)it commit -m "提示信息B" 即可。

到此,相信大家對“Git機(jī)制的知識點(diǎn)有哪些”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

git
AI