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

来源:https://www.cnblogs.com/qiaogeli/archive/2019/10/13/11668553.html
-Advertisement-
Play Games

本文首發於微信公眾號:程式員喬戈里 轉載請註明:https://blog.csdn.net/WantFlyDaCheng/article/details/102538508 一、兩次的 git commit 到不是同一個遠程分支 這裡由於提交自己的代碼第一次提交到A分支,第二次提交B分支,然後報錯了 ...


本文首發於微信公眾號:程式員喬戈里 轉載請註明: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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 主要用代碼註釋來初步學習OpenCV-Python 1. 圖片初使用(結合matplotlib) 2. 視頻初使用 ...
  • 新聞 ".NET架構指南" "美妙的WebSharper:學術刊物" ".NET Core 3.0中Blazor Server的方案與性能" "Mono 6.4.0發佈說明" "CapitolFSharp召集發言人" 視頻及幻燈片 "函數式反應型編程中的實時流分析" "領域模型函數式化" "臨近十月 ...
  • 錯誤信息: 解決方法: 找到對應文件 找到出錯語句: 去掉末尾那個逗號即可。 ...
  • 範例:JDBC查詢 package com.hsp; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import jav ...
  • 1.面向對象和麵向過程的區別? 面向過程:面向過程性能比面向對象高 面向對象:面向對象易維護、易復用、易擴展 面向過程:面向過程性能比面向對象高 面向對象:面向對象易維護、易復用、易擴展 2.Java 語言有哪些特點? 簡單易學、面向對象(封裝,繼承,多態)、平臺無關性( Java 虛擬機實現平臺無 ...
  • Thymeleaf在模板中使用 #dates 或 #calendars 兩個對象來處理日期,這兩個對象大部分類似。 ...
  • 本文主要講解Spring開發中三種不同的註入方式,以及集合數據類型的註入,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 首先看一下@FeignClient註解的源碼: 可以看出@FeignClient註解被@Target(ElementType.TYPE)修飾,表示@FeignClient註解的作用目標在介面上。 針對其常用屬性做如下歸納: String name():指定FeignClient的名稱,如果項目使用了 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...