最近學到的Git知識,大廠的Git機制還是很方便的
本文首發於微信公眾號:程式設計師喬戈裡 轉載請註明:https://blog.csdn.net/WantFlyDaCheng/article/details/102538508
一、兩次的 git commit 到不是同一個遠端分支
- 這裡由於提交自己的程式碼第一次提交到A分支,第二次提交B分支,然後報錯了,這裡報錯以後,會提示一個百度自己內部的連結,你點選連結就可以照著提示去修改,可以說還是省了不少事,不用自己去google百度去解決,開發效率也提高不少
上面圖片中有6e8713f is CR parent commit 這行提示,劃重點,待會要用到。
解決過程
你當前的操作場景如下圖,由於一次CR(評審)的多個commits不能push到不同的refs/for/[分支名](可能導致後續評審合入merge failed):
評審是啥意思,這裡解釋一下。本地開發的流程首先是從自己遠端的分支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有什麼不同,需要撤銷修改
- 不小心勿加了空行
- 就是想撤銷已經提交的某個檔案的修改
如何操作
1.撤銷快取區的修改
git reset HEAD filename
- 撤銷工作區的修改
git checkout --filename
三、git 衝突解決
上圖是提交程式碼時候,發生了衝突,依舊很貼心,百度這套程式碼審查系統依舊給了提示,照著提示操作一波。
Step1. 在本地倉庫中, 更新併合並程式碼
git fetch origin
git rebase origin/master
Step2. 依據提示分別開啟衝突的檔案,逐一修改衝突程式碼
- 可以看到有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進行漫畫講解,幫助你快速搞懂演算法!
相關推薦
最近學到的Git知識,大廠的Git機制還是很方便的
本文首發於微信公眾號:程式設計師喬戈裡 轉載請註明:https://blog.csdn.net/WantFlyDaCheng/article/details/102538508 一、兩次的 git commit 到不是同一個遠端分支 這裡由於提交自己的程式碼第一次提交到A分支,第二次提交B分支,然後報錯
mzy git學習,初識git(一)
GIT學習 git工作區、暫存區、本地庫、遠端庫 工作區:實際上我們工作的地方,進行寫程式碼或者檔案的地方。 暫存區:我們執行了git add 操作之後,就會被提交到暫存區。 本地庫:其實最後我們需要執行這一步操作,git commit 到本地庫中,才表示完結了。 但是大家
Git 剖析,以及Git相關操作
本地庫 想要 暫存區 htm 圖形界面 初始化 git fetch windows 文件 Git的安裝: Windows上操作。 1、安裝安裝包地址: http://msysgit.github.io/ 一路next,直接安裝上,完成安裝之後,就可以使用命令行的 git
Git知識總覽(五) Git中的merge、rebase、cherry-pick以及互動式rebase
上篇部落格聊了《》本篇部落格我們就以Learning Git中的關卡進行展開。下方列舉了LearningGit中的 merge、rebase、reset、revert、cherry-pick 以及互動式rebase相關關卡的操作以及對應的解析。後邊在聊互動式rebase操作是,不單單給出了LearningGi
Git知識總覽(四) git分支管理之rebase 以及 cherry-pick相關操作
上篇部落格聊了《》,本篇部落格我們主要來看一下 rebase 變基相關的操作。rebase 操作和 merge 操作最終都可以達到合併程式碼的效果,不過其對分支的影響不同。上篇部落格中我們聊到了 merge操作。簡單的說merge操作就是將兩個commit進行合併,然後在這兩個分支合併的基礎上建立一個新的co
Git知識總覽(二) git常用命令概覽
上篇部落格我們從 git clone 和 git status 兩個命令開始,引出了一系列的git操作命令, 請參見:《》。上篇部落格中所涉及的git命令也是git命令操作中常用的基礎操作命令,本篇部落格繼續來總結一下git使用時常用的命令操作以及其他相關基礎知識。 下方是本篇部落格所會涉及的內容: .g
Git知識總覽(六) Git分支中的遠端操作實踐
前幾篇部落格陸陸續續的講了好多關於Git操作的內容, 其中在上篇部落格聊了《》,本篇部落格仍然也不例外,不過本篇部落格的主題是關於git的遠端操作的。依照之前部落格的風格,我們依然依託於LearningGitBranch中的相關內容來探究一下Git的遠端操作。今天這篇部落格算是Git系列部落格的結尾了。 一、
MyEclipse專案,使用自帶Git外掛,新增Git支援(SSH方式)
本文,主要總結使用MyEclipse自帶的Git外掛,對MyEclipse專案新增Git支援。 同時,登入遠端伺服器,使用的是SSH方式。 主要步驟如下: 一、建立本地的Git倉庫。 1、右鍵專案,依次點選 Team-->Share Project 。 2、有C
Git知識總覽(六) Git分支中的遠程操作實踐
9.png git操作 checkout 遠程分支 目標 merge 指定 本地 git pull 前幾篇博客陸陸續續的講了好多關於Git操作的內容, 其中在上篇博客聊了《Git中的merge、rebase、cherry
git知識總結2——建立版本庫,新增/提交檔案
1.建立版本庫 版本庫又名倉庫,英文名repository,你可以簡單理解成一個目錄,這個目錄裡面的所有檔案都可以被Git管理起來,每個檔案的修改、刪除,Git都能跟蹤,以便任何時刻都可以追蹤歷史,或者在將來某個時刻可以“還原”。 首先,選擇一個合適的地方,建立一個空目錄 cd 命令用於切
Git憑證儲存(簡單易懂,一學就會,認真看)
今天給自己提了一個問題,當我們在github.com或者gitlab上面新建倉庫,並克隆到本地,首次使用的時候,會被問及使用者名稱密碼,但是這兩個資訊存在哪裡呢? 帶著這個問題,我開始搜尋,並在《Pro Git》7.14 Git-工具-憑證儲存中讀到了完整的解答,但是當我第一次閱讀的時候,並沒有太清楚它所要表
Git-少年,你想學回滾嗎?想撤銷檔案修改嗎?
哎呀呀,夏天,哪裡涼快滾哪裡,冬天,哪裡暖和滾哪裡 寫在前面 林俊杰有首歌《可惜沒如果》,道盡後悔的遺憾,但是萬幸,在 Git 中你可以擁有如果,用 reset、checkout 和 revert 可以用來撤銷當年那些錯誤的決定。 帶著 Git
02_創建Git倉庫,克隆倉庫,git add,git commit,git push,git pull,同行沖突,不同行沖突的結局方案,git mergetool的使用
round rom weight art sdn automatic remote then config 1 創建Git資源庫,殘酷文件夾信息 創建git資源庫的命令: git init –bare 倉庫名稱 (當中-bare表示的意思是空的庫的意思)
創建局域網內遠程git倉庫,並將本地倉庫push推到遠程倉庫中
目錄 html fatal targe images rem url already tle 轉自原文 創建局域網內遠程git倉庫,並將本地倉庫push推到遠程倉庫中 1. 先遠程登錄局域網內服務器 2. 在服務器裏 切換到某個文件夾下, 然後新建一個
解決因為本地代碼和遠程代碼沖突,導致git pull無法拉取遠程代碼的問題
git 沖突一、問題 當本地代碼和遠程代碼有沖突的時候,執行git pull操作的時候,會提示有沖突,然後直接終止本次pull,查了些資料沒有找到強制pull的方式,但是可以使用如下方式解決。 二、解決思路 可以先將本地內容stash到倉庫中,執行stash操作後,本地代碼將返回到修改前的內容。這時,就可
第一次使用github、git工具,本地倉庫、遠程倉庫使用
git工具 控制系統 align 第一次 測試 控制 windows版本 .net out 一次使用git,記錄下使用過程。。。可能還有很多東西可能還沒理解,後期理解了再寫吧 git是什麽.,百度的回答: 一:Git是什麽? Git是目前世界上最先進的分布
最近的一點思考,關於高手/大師/學霸
一點 現在 考試 比較 吐槽 垃圾 一切都 離開 pan 最近重新學習線代,微積分,概率論。大學的時候就沒有好好學過,覺得概念,公式太多,而且很多難以理解。 而我自己一直認為數學能力還是不錯的。但是到大學以後,覺得完全跟不上,和邊上的人交流,包括學生和工作以後的人交流,完全
git安裝,配置和使用
查看 -name 隱藏 user 遠程倉庫 color read 現場 branch 基礎操作 需要一個文件夾作為版本庫 建立倉庫git init 添加文件git add filename 提交文件git commit -m "info" 查看日誌git log//—pr
【知識小結】Git 個人學習筆記及心得
art over round TP 緩存 PE QQ 的區別 rda https://mp.weixin.qq.com/s/D96dXYfu3XAA4ac456qo0g git架構 工作區:就是你在電腦裏能看到的目錄。 版本庫:工作區有一個隱藏目錄.git,,而是
git-it 教程,一些git知識點。
hub 電腦 onf 所有 pan one sfm 變化 gin https://github.com/jlord/git-it-electron#what-to-install 一個git使用教程 看剛才改變的文件的區別。git diff: Add GitHub use