最近學到的Git知識,大廠的Git機制還是很方便的


本文首發於微信公眾號:程序員喬戈里 轉載請注明:https://blog.csdn.net/WantFlyDaCheng/article/details/102538508

一、兩次的 git commit 到不是同一個遠程分支

undefined

  • 這里由於提交自己的代碼第一次提交到A分支,第二次提交B分支,然后報錯了,這里報錯以后,會提示一個百度自己內部的鏈接,你點擊鏈接就可以照着提示去修改,可以說還是省了不少事,不用自己去google百度去解決,開發效率也提高不少
  • 上面圖片中有6e8713f is CR parent commit 這行提示,划重點,待會要用到。

解決過程

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

undefined

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

  • 本次合並我最終的目的是要合到B分支(第一次提交是A分支,第二次是B分支)
  • 如果你期望commit 1和commit 2均合入分支B:
  • 請回滾本地commit,重新合並為同一筆commit push至分支 B (會生成一筆新的評審)

操作命令

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

二、git 撤銷文件修改

什么時候用到

  • 如果有文件A沒有發生修改,但是再提交評審的時候還是發現A出現了修改,你使用git diff 並沒有發現你的本地文件A和遠程分支A有什么不同,需要撤銷修改
  • 不小心勿加了空行
  • 就是想撤銷已經提交的某個文件的修改

如何操作

undefined

1. 撤銷緩存區的修改

git reset HEAD filename
  1. 撤銷工作區的修改
git checkout --filename

三、git 沖突解決

undefined
上圖是提交代碼時候,發生了沖突,依舊很貼心,百度這套代碼審查系統依舊給了提示,照着提示操作一波。

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

git fetch origin
git rebase origin/master

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

  • undefined
  • undefined
  • 可以看到有head和你的本次提交信息,head是遠程分支,git commit -m "commit提交信息" 這條命令中我填的是689任務,可以看到每有一處信息不一致,在你產生沖突的文件都會提示出來。
  • 我們需要做的就是解決沖突,對比遠程和你本地產生沖突的地方,保留下你需要的代碼,同時記得把head和689任務(commit提交信息)這些不是代碼中的內容刪除掉。
  • 或者不需要這樣一點點修改,你已經知道了你需要提交什么樣的代碼,那么直接將你確定好沒問題的代碼復制到這份沖突文件中,然后進行git三連即可

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

git add -u
git rebase --continue

Step4. 更新patch

git push origin HEAD:refs/for/master

四、撤銷你的commit提交

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

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

你發現自己的提示信息寫的不對,想git commit -m "提示信息B",但是由於已經git commit 過了,會提示你沒有什么需要git commit的,這個時候如何撤銷git commit呢?

git reset --soft HEAD^

這樣上一次提交就被撤回了,然后繼續執行git commit -m "提示信息B" 即可。

如果是頭條用戶,可以在我的頭條號 程序員喬戈里 私信我 資源 獲取價值29998元的編程和考研資料
覺得文章不錯的歡迎關注我的WX公眾號:程序員喬戈里
我是BAT大廠后台開發工程師,專注分享技術干貨/編程資源/求職面試/成長感悟等,關注送5000G編程資源和自己整理的一份幫助不少人拿下Offer的整理一份面試資料《技術面試必備基礎知識》,覆蓋了Java核心技術、JVM、Java並發、SSM、微服務、數據庫、數據結構、Leetcode 題解、、C++、Python、后端面試、操作系統、計算機網絡、系統設計等等。關注公眾號並回復 888 領取,免費下載CSDN資源。

如果你對算法感謝趣,歡迎關注我的公眾號 圖解算法,使用Python/Java/前端/C++四種語言對Leetcode和劍指offer進行漫畫講解,幫助你快速搞懂算法!

圖解算法.jpg


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM