Git實戰演練,模擬日常使用,快速掌握命令

01 引言

上一期借助Idea,完成了Git倉庫的建立、配置、代碼提交等操作,初步入門了Git的使用。然而日常開發中經常面臨各種各樣的問題,入門級的命令遠遠不夠使用。

這一期,我們將展開介紹Git的日常處理命令,解決日常問題,熟悉Git操作。

02 Git分支管理

一個新的項目開始,我們需要從主干分支上拉取開發分支。我們還是以上一期的project-test 倉庫為例。

2.1 創建新的分支

按照下圖所示操作:

創建dev-20250520分支:

Git命令:

# 創建新分支
git checkout -b dev-20250520 origin/main# 切換分支
git checkout dev-20250520

查看所有本地和遠程分支:
在這里插入圖片描述

對應的命令:

# 查看所有本地和遠程分支
git branch -a# 查看遠程分支
git branch -r# 查看本地所有分支
git branch

2.2 提交代碼

編寫實例代碼,直接提交到本地倉庫。

其實也可以直接從控制臺看看Git執行了哪些命令:

2.3 推送到遠程倉庫

首次推送到遠程倉庫會自動創建分支名的遠程倉庫分支。正常開發中我們的代碼應該是直接從分支項目檢出的,不需要創建遠程倉庫的分支。

遠程倉庫查看:

03 處理沖突

為了制造沖突,直接在GitHub上修改GitTest.java文件。

3.1 制造沖突

本地修改同一個文件(GitTest.java),提交本地倉庫沒有沖突,但是推送遠程倉庫時,就會出現沖突。

image-20250520171334778

3.2 解決沖突

沖突的解決保留歷史分支記錄,我們一般會選擇Merge處理。

選擇Merge之后,Git會自動從遠程倉庫拉取最新的代碼,并在工作區標記處沖突的位置(如上圖)。我們通過Idea繼續Merge處理沖突。

左右兩側分別表示本地倉庫和遠程倉庫,中間是處理的最終結果。黃色代表相對去中間工作區的改動的地方。點擊箭頭即可完成代碼移動。

假設我們兩邊的代碼都需要,我們只要一次點擊箭頭即可完成代碼的合并(沖突的解決),再次提交到本地倉庫。

代碼提交到本地倉庫之后,就可查看該分支的所有變更記錄:

也可以通過命令查看:

# 查看歷史提交記錄
git log

命令結果:

最后推送到遠程倉庫即可。

04 代碼回滾

代碼回滾是一個優秀的設計。網上不是有這樣的梗,產品做了第一版方案后給老板看,老板覺得不滿意,然后來來回回的改,最后老板覺得還是第一版比較好。產品的心中一萬只羊駝奔騰而過。

程序員同樣面臨的這樣的場景,但是代碼回滾完美的解決了這樣的問題。

我們模擬三版提交方案。在GitTest.java增加提交的版本信息:

/***  第一版提交方案*/
private void firstCase() {System.out.println("第一版Case");
}/***  第二版提交方案*/
private void secondCase() {System.out.println("第二版Case");
}/***  第三版提交方案*/
private void thirdCase() {System.out.println("第三版Case");
}

假設我們要回到第一版的方案:

選中第一版記錄,然后右鍵復制版本號

4.1 未推送遠程的回滾

命令:

# --hard 底回退到指定提交,丟棄所有未提交的更改
# –mixed(默認):移動 HEAD 并重置暫存區,但保留工作區修改
# –soft:僅移動 HEAD,保留工作區和暫存區
git reset --hard 回退的版本號

結果迅速到達第一版:

4.2 已推送至遠程的回滾

命令:

# 回退到指定的版本號
git revert 版本號

如果是相同的位置的代碼修改可能會出現沖突,正常解決即可

解決之后,需要重洗提交代碼。

05 合并分支

代碼合并階段一般是出現在開發分支過久,迭代多次需要合并新分支,另外一個就是發布代碼之后,必須將代碼合并到主干上。

案例中我們一直在dev-20250520開發,我們將開發分支合并到主干(main)分支上。首先我們需要需要切換分支到主干分支上。

切換分支的命令:

# 切換到主干分支上
git checkout main

Idea的操作:

切到主干分支發現并沒有GitTest.java的文件:

分支合并:

合并之后代碼會之間保存到暫存區,直接推送到遠程即可:

06 小結

今天就一個簡單的模擬實戰項目,練習了Git日常處理問題的命令。如果有什么更加有趣的命令,評論區留言討論!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/84507.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/84507.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/84507.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

wordpress主題開發中常用的12個模板文件

在WordPress主題開發中,有多種常用的模板文件,它們負責控制網站不同部分的顯示內容和布局,以下是一些常見的模板文件: 1.index.php 這是WordPress主題的核心模板文件。當沒有其他更具體的模板文件匹配當前頁面時,Wor…

數據庫blog5_數據庫軟件架構介紹(以Mysql為例)

🌿軟件的架構 🍂分類 軟件架構總結為兩種主要類型:一體式架構和分布式架構 ● 一體化架構 一體式架構是一種將所有功能集成到一個單一的、不可分割的應用程序中的架構模式。這種架構通常是一個大型的、復雜的單一應用程序,包含所…

離線服務器算法部署環境配置

本文將詳細記錄我如何為一臺全新的離線服務器配置必要的運行環境,包括基礎編譯工具、NVIDIA顯卡驅動以及NVIDIA-Docker,以便順利部署深度學習算法。 前提條件: 目標離線服務器已安裝操作系統(本文以Ubuntu 18.04為例&#xff09…

chromedp -—— 基于 go 的自動化操作瀏覽器庫

chromedp chromedp 是一個用于 Chrome 瀏覽器的自動化測試工具,基于 Go 語言開發,專門用于控制和操作 Chrome 瀏覽器實例。 chromedp 安裝 go get -u github.com/chromedp/chromedp基于chromedp 實現的的簡易學習通刷課系統 目前實現的功能&#xff…

高級特性實戰:死信隊列、延遲隊列與優先級隊列(三)

四、優先級隊列:優先處理重要任務 4.1 優先級隊列概念解析 優先級隊列(Priority Queue)是一種特殊的隊列數據結構,它與普通隊列的主要區別在于,普通隊列遵循先進先出(FIFO)的原則,…

python打卡day34

GPU訓練及類的call方法 知識點回歸: CPU性能的查看:看架構代際、核心數、線程數GPU性能的查看:看顯存、看級別、看架構代際GPU訓練的方法:數據和模型移動到GPU device上類的call方法:為什么定義前向傳播時可以直接寫作…

Newtonsoft Json序列化數據不序列化默認數據

問題描述 數據在序列號為json時,一些默認值也序列化了,像旋轉rot都是0、縮放scal都是1,這樣的默認值完全可以去掉,減少和服務器通信數據量 核心代碼 數據結構字段增加[DefaultValue(1.0)]屬性,縮放的默認值為1 public class Vec3DataOne{[DefaultValue(1.0)] public flo…

可增添功能的鼠標右鍵優化工具

軟件介紹 本文介紹一款能優化Windows電腦的軟件,它可以讓鼠標右鍵菜單添加多種功能。 軟件基本信息 這款名為Easy Context Menu的鼠標右鍵菜單工具非常小巧,軟件大小僅1.14MB,打開即可直接使用,無需進行安裝。 添加功能列舉 它…

Gemini 2.5 Pro 一次測試

您好,您遇到的重定向循環問題,即在 /user/messaging、/user/login?return_to/user/messaging 和 /user/login 之間反復跳轉,通常是由于客戶端的身份驗證狀態檢查和頁面重定向邏輯存在沖突或競爭條件。 在分析了您提供的代碼(特別…

vue3前端后端地址可配置方案

在開發vue3項目過程中,需要切換不同的服務器部署,代碼中配置的服務需要可靈活配置,不隨著run npm build把網址打包到代碼資源中,不然每次切換都需要重新run npm build。需要一個配置文件可以修改服務地址,而打包的代碼…

大模型微調與高效訓練

隨著預訓練大模型(如BERT、GPT、ViT、LLaMA、CLIP等)的崛起,人工智能進入了一個新的范式:預訓練-微調(Pre-train, Fine-tune)。這些大模型在海量數據上學習到了通用的、強大的表示能力和世界知識。然而,要將這些通用模型應用于特定的下游任務或領域,通常還需要進行微調…

編程技能:字符串函數10,strchr

專欄導航 本節文章分別屬于《Win32 學習筆記》和《MFC 學習筆記》兩個專欄,故劃分為兩個專欄導航。讀者可以自行選擇前往哪個專欄。 (一)WIn32 專欄導航 上一篇:編程技能:字符串函數09,strncmp 回到目錄…

動態規劃-53.最大子數組和-力扣(LeetCode)

一、題目解析 在給定順序的數組中找出一段具有最大和的連續子數組,且大小最小為1. 二、算法原理 1.狀態表示 我們可以意一一枚舉出所有的子數組,但我們想要的是最大子數組,所以f[i]表示:以i位置為結尾,所有子數組的最…

C++ queue對象創建、queue賦值操作、queue入隊、出隊、獲得隊首、獲得隊尾操作、queue大小操作、代碼練習

對象創建&#xff0c;代碼見下 #include<iostream> #include<queue>using namespace std;int main() {// 1 默認構造函數queue<int> q1;// 2 拷貝構造函數queue<int> q2(q1);return 0;} queue賦值操作&#xff0c;代碼見下 #include<iostream>…

全鏈路解析:影刀RPA+Coze API自動化工作流實戰指南

在數字化轉型加速的今天&#xff0c;如何通過RPA與API的深度融合實現業務自動化提效&#xff0c;已成為企業降本增效的核心命題。本文以「影刀RPA」與「Coze API」的深度協作為例&#xff0c;系統性拆解從授權配置、數據交互到批量執行的完整技術鏈路&#xff0c;助你快速掌握跨…

php本地 curl 請求證書問題解決

錯誤: cURL error 60: SSL certificate problem: unable to get local issuer certificate (see https://curl.haxx.se/libcurl/c/libcurl-errors.html) for 解決方案 在php目錄下創建證書文件夾, 執行下面生成命令, 然后在php.ini 文件中配置證書路徑; 重啟環境 curl --eta…

【圖數據庫】--Neo4j 安裝

目錄 1.Neo4j --概述 2.JDK安裝 3.Neo4j--下載 3.1.下載資源包 3.2.創建環境變量 3.3.運行 Neo4j 是目前最流行的圖形數據庫(Graph Database)&#xff0c;它以節點(Node)、關系(Relationship)和屬性(Property)的形式存儲數據&#xff0c;專門為處理高度連接的數據而設計。…

MIT 6.S081 2020Lab5 lazy page allocation 個人全流程

文章目錄 零、寫在前面一、Eliminate allocation from sbrk()1.1 說明1.2 實現 二、Lazy allocation2.1 說明2.2 實現 三、Lazytests and Usertests3.1 說明3.2 實現3.2.1 lazytests3.2.2 usertests 零、寫在前面 可以閱讀下4.6頁面錯誤異常 像應用程序申請內存&#xff0c;內…

(Git) 稀疏檢出(Sparse Checkout) 拉取指定文件

文章目錄 &#x1f3ed;作用&#x1f3ed;指令總覽&#x1f477;core.sparseCheckout&#x1f477;sparse-checkout 文件 &#x1f3ed;實例演示?END&#x1f31f;交流方式 &#x1f3ed;作用 類似于 .gitignore 進行文件的規則匹配。 一般在需要拉取大型項目指定的某些文件…

docker初學

加載鏡像&#xff1a;docker load -i ubuntu.tar 導出鏡像&#xff1a;docker save -o ubuntu1.tar ubuntu 運行&#xff1a; docker run -it --name mu ubuntu /bin/bash ocker run -dit --name mmus docker.1ms.run/library/ubuntu /bin/bash 進入容器&#xff1a;docke…