Git命令彙總(基礎篇)

来源:http://www.cnblogs.com/garryfu/archive/2017/12/05/7985591.html
-Advertisement-
Play Games

自己用Git有一段時間了,隨著項目越來越多,功能分支也隨之增加,從簡單的基礎命令到隨心所欲,需要自己不斷地去嘗試總結,下麵來分享一下我的Git使用總結。 本章基礎篇主要講解一些Git代碼提交流程和Git基礎命令的使用。 一、Git版本分支管理 以下是一個比較基本的分支管理示範,每個公司的項目管理運作 ...


自己用Git有一段時間了,隨著項目越來越多,功能分支也隨之增加,從簡單的基礎命令到隨心所欲,需要自己不斷地去嘗試總結,下麵來分享一下我的Git使用總結。

本章基礎篇主要講解一些Git代碼提交流程和Git基礎命令的使用。

一、Git版本分支管理

以下是一個比較基本的分支管理示範,每個公司的項目管理運作不同,分支管理也有各自的特色,但萬變不離其宗。

1) dev分支用於日常開發

2) 當有新版本需要發佈時,把dev代碼合併到release分支做集成測試,並等待發佈

3) release分支進入bug修複階段

4) 如果在release分支發現bug,那麼在release分支進行修改,並使用git cherry-pick把修複bug的commit合併到release分支上

(cherry-pick與merge不同,它的合併是以commit為單位而非整個branch)

完成後,release分支上所有代碼改動(除版本號之外)都應該已經合到了dev分支上

5) release分支測試完成後,發佈到線上環境

6) 並且打上tag,合併到master分支上

7) 如果線上上出現bug,那麼在master上hot fix修複

8) 出現hot fix並修複後,需要重新把hot fix的代碼合併到dev以及release分支中去使代碼保持一致

  

二、Git基本命令彙總

1.查看本地文件狀態

git status  —-查看本地、本地倉庫、緩存(stash)的文件修改狀態 

—紅色 代表本地工作空間的文件修改

—藍色 代表提交到本地倉庫中的文件(git add .)

2.切換版本/覆蓋當前修改文件

git branch - 查看當前版本 

git branch -a 查看所有版本

git checkout XXX(版本名)  —-切換到遠程庫中XXX版本

git checkout filepath    —覆蓋當前修改的文件

git checkout .           -覆蓋當前所有修改文件

3.從遠程庫獲取最新代碼

git remote -查看遠程庫名稱 

git remote -v   

git remote show XXX(遠程庫名)

git fetch — 從remote端拉取最新代碼

git pull XXX(遠程庫名) XXX(分支名)  -把拉取的最新代碼跟當前工作空間合併

git rebase —把遠程拉回的代碼和本地合併

4.緩存本地代碼

當要切換到其它版本時,想保存在當前版本修改的文件:在切換前做

git stash   —-把本地修改過不需要提交的文件放入緩存

git checkout XXX(版本)   —切換庫版本

切回原來的庫,把文件從stash緩存中拿出來

git stash pop — 從緩存中拉出

5.提交遠程庫

git add .

git commit -m ''

git remote 查看遠程關聯名稱

git push remote的名稱 本地master

6.處理衝突 

git fetch 拉取最新工程

git pull XXX(遠程庫名) XXX(分支名)  -把拉取的最新代碼跟當前工作空間合併

衝突產生後,去工作空間修改後,>>>新代碼===老代碼<<<,保留最終代碼,刪除提示符,重新提交。

7.把本次提交的內容提交到其他分支(比如發佈時bug的修改)

git cherry-pick commitId

8.建議執行順序

git status 查看修改狀態

git checkout filename 放棄某文件的修改。

git stash 儲存修改

git fetch 拉取最新工程

git rebase 與本地分支合併

git stash pop 彈出儲存文件,此時新文件可能會與你的文件產生衝突,解決衝突。

git add filename 添加某個修改文件

git add . 提交所有加點

git reset HEAD filename 回滾指定文件,回滾所有加點:"git reset HEAD . "

git commit -m''

git push 本地remote遠程分支名,本地分支名

例我的本地分支為master 遠程remote 別名為 origin 則提交為git push origin master

9.切換HEAD

git reflog --查看HEAD記錄

git reset --hard HEAD^       //切換到之前一個HEAD  

git reset --hard fad4462      // 切換到某個已經回退的HEAD

10.刪除 local branch

git branch -d <branch_name>

 


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

-Advertisement-
Play Games
更多相關文章
  • 在java中,使用suspend()方法暫停線程,使用resume()方法恢複線程的執行。 1.8.1suspend與resume的使用: 線程代碼: 執行代碼: 執行結果: 從執行的時間來看,新開啟的線程確實發生了暫停(當前線程暫停與啟動的時間與另外開啟的線程是一致的),並且能夠成功的恢復運行狀態 ...
  • 一、安裝Git 1.安裝git,點擊Git Bash進入命令行視窗頁面 2.配置:$ git config --global user.name "Your Name"$ git config --global user.email "[email protected]"註意git config命令 ...
  • 相關網頁:Java序列化的高級認識http://www.360doc.com/content/13/0728/18/13247663_303173972.shtml 以下程式來自”http://bbs.csdn.net/topics/390155251“(已驗證) 類Student1 package ...
  • 這是LeetCode上的題目56. Merge Intervals中需要用到的, 簡單來說,定義了E為 同時一個List 需要按照Interval中start參數的大小進行排序,看起來很複雜,其實就只要一句話: 意思大家都能看出來,重寫了compare方法,很簡單,寫這個也是為了自己之後使用的時候能 ...
  • 為何說python函數定義預設參數必須指向不可變對象? 以下是個人的理解,如有不對的地方,歡迎討論 原因分析:函數在定義時就分配了函數和預設參數L所指向對象的記憶體空間。 1. 如果L指向的是可變對象,函數中更新這個可變對象,那麼在多次調用函數,更新的都是函數定義時創建的可變對象, 這個可變對象不會隨 ...
  • JS分頁 1> JS分頁,業務邏輯 (1) 分頁採用的是一個叫jquery.pagination.js的一個jquery插件 (2) 需要jquery的支持,此項目中使用到的是jquery-2.1.1.min.js (3) 分頁需要的參數有:記錄總數,每頁顯示個數,頁碼 (4) 添加搜索的條件,作為 ...
  • ##二分查找法 def binary_search(data, find_n): if len(data) >= 1: mid = int(len(data) / 2) if find_n < data[mid]: binary_search(data[:mid], find_n) elif fin ...
  • 你是否想過用所學的Python開發一個圖形界面的聊天室程式啊? 像這樣的: 如果你想開發這樣一個有點懷舊風格的聊天程式,那麼可以接著看; 要開發這個聊天程式,你需要具備以下知識點: asyncore 、asynchat模塊使用 wxPython 圖形開發 這個聊天程式的實驗原理如下: 由於 Pyth ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...