Git分支操作與遠程倉庫的使用

Git分支操作

  • 本地倉庫
    • 創建分支
    • 合并分支
    • 刪除分支
  • 遠程倉庫
    • push 推送遠程分支
    • pull 拉取遠程分支
    • fetch 更新遠程分支
    • 本地分支與遠程分支的跟蹤關系

本地倉庫

由于Git的分布式特性,所以沒有絕對的本地和遠程概念,一切都是相對的。對于分支的操作,個人認為其實重點在于本地的分支操作,而對于遠程倉庫的分支操作歸結起來只有 推送拉取

創建分支

創建本地分支有兩種命令方式,第一是使用分支命令branch,第二是使用查看命令checkout

推薦使用查看命令 :git checkout -b <new_branch_name>,它是下面兩條命令的簡寫

git branch <new_branch_name>
git checkout <new_branch_name>

深度應用,在某個場景下,當我們的項目在不斷推進后,老板突然說:“第一版其實還不錯,我們再看一下”,我:“…”。

這時我們當然可以使用回滾或者查看歷史版本的方式,在這之前先備份一下當前代碼,又或者創建個分支保護一下什么的,但是這樣做仍然可能會很危險,亦或者很麻煩,這個時候我們就會想,如果能在第一版有個分支就好了。是的,我們還可以根據某個歷史提交狀態來創建一個分支。

仍然使用查看命令git checkout -b <branch_name> <SHA-1>,使用歷史提交版本的SHA-1校驗和來創建指定歷史版本的分支,SHA-1校驗和的值可以通過git log查看,它實際上也是多個命令的簡寫

git checkout <SHA-1>
git branch <branch_name>
git checkout <branch_name>

git checkout -b甚至可以根據遠程倉庫來創建本地分支,git checkout -b <local_branch> <remote>/<remote_branch>

說明:git branch會根據當前的代碼狀態創建分支,不管這個狀態是最終狀態還是某個歷史狀態,git checkout 查看 / 切換分支,也可以查看某個歷史版本

除此之外,還能使用git checkout --orphan <branch_name>創建一個空白分支

命令總結

  • git checkout -b <branch_name> 創建分支
  • git checkout -b <branch_name> <SHA-1> 在歷史版本SHA-1位置創建分支
  • git checkout -b <branch_name> <remote>/<remote_branch> 基于遠程分支創建分支
  • git checkout --orphan <branch_name> 創建空白分支

合并分支

git提供了兩種合并指令 mergerebase,用于將兩個或兩個以上的開發歷史加入(合并)一起。如果合并沒有沖突,則會自動進行一次提交。

git merge <branch_name>,將 branch_name 分支合并到當前分支

刪除分支

  • 使用git branch -d <branch_name>來刪除指定分支,及時的刪除一些無用分支是個良好的習慣,不然我們將在眾多分支中暈頭轉向。
  • 使用git remote prune <remote> 來清除本地緩存的無效遠程分支指針

遠程倉庫

實際上并不存在顯性的對遠程分支的操作,所有對遠程分支的操作都是 push 的副作用。

對遠程倉庫的操作一般時 fetch,pull 和 push,這個操作的意義在于同步遠程倉庫和本地倉庫,更確切的說法是將本地倉庫的某條分支和遠程倉庫的某條分支進行同步

比如本地倉庫有 mastertest 兩條分支,遠程倉庫有 masterdevelop 兩條分支,我們可以將遠程倉庫的 develop 分支同步到本地的 master 分支上,也可以將本地的 master 分支同步到遠程倉庫的 master 分支上,同步的實質時合并兩條分支,如果是兩條不相關的分支,則不能合并,即推送 / 拉取不成功(強行推送 / 拉取除外)。

push 推送遠程分支

push的完整寫法是:

git push <remote> <local_branch>:<remote_branch>

意思是將本地 local_branch 分支推送到遠程倉庫的 remote_branch 分支,并進行 merge 合并,如果遠程倉庫沒有 remote_branch 分支則會創建分支,所以在遠程分支不存在的情況下,該操作相當于創建遠程分支

  • 省略遠程分支名 git push <remote> <local_branch> ,git會推送local_branch分支到遠程倉庫的與本地分支同名的遠程分支
    eg:git push origin dev 相當于 git push origin dev:dev 的簡寫

  • 省略本地分支名 git push <remote> :<remote_branch> ,Git會刪除遠程倉庫上的remote_branch分支,即用一個空分支更新remote_branch分支,相當于刪除遠程分支
    eg:git push origin :dev 相當于 git push origin --delete dev

  • 省略所有分支名 git push <remote> ,如果當前分支和遠程分支存在追蹤關系,則本地分支和遠程分支都可以忽略。如果當前分支只有一個遠程主機,那么遠程主機也可以省略。

  • git push --all <remote> 將本地的所有分支都推送到遠程主機。

  • git push --force <remote> [<local_branch>:<remote_branch>] 當服務器上版本和本地版本不一致時,push會發生沖突,git會提示我們先使用pull來解決沖突,如果一定要推送,可以使用這個命令,除非一定要這樣,否則應該避免使用force。

pull 拉取遠程分支

和push類似,pull的完整寫法是(注意本地分支和遠程分支的順序):

git pull <remote> <remote_branch>:<loacl_branch>

意思是將遠程倉庫 remote_branch 分支拉取到本地倉庫的 local_branch 分支,并進行merge合并,如果本地倉庫沒有 local_branch 分支則會創建分支。

  • 省略本地分支名 git pull <remote> <remote_branch> ,git會拉取remote_branch分支當前本地分支

  • 省略所有分支名 git pull <remote> ,如果當前分支和遠程分支存在追蹤關系,則本地分支和遠程分支都可以忽略。如果當前分支只有一個遠程主機,那么遠程主機也可以省略。

  • git pull <remote> --rebase 合并的時候采用rebase模式

fetch 更新遠程分支

git pull 實際上是 git fetchgit merge 的聯合操作

git pull origin master

相當于

git fetch origin master
git merge origin/master

本地分支與遠程分支的跟蹤關系

  • git branch -vv 查看分支跟蹤情況
  • git branch --set-upstream-to=<remote>/<branch_name> <branch_name> 將branch_name分支追蹤遠程分支remote/branch_name
  • git branch -u <remote>/<branch_name> 設置當前分支追蹤遠程分支 remote/branch_name

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

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

相關文章

SimMechanics/Second Generation倒立擺模型建立及初步仿真學習

筆者最近搗鼓Simulink&#xff0c;發現MATLAB的仿真模塊真的十分強大&#xff0c;以前只是在命令窗口敲點代碼&#xff0c;直到不小心敲入simulink&#xff0c;就一發不可收拾。話說simulink的模塊化建模確實方便&#xff0c;只要拖拽框框然后雙擊設置屬性就可以慢慢堆建自己的…

10 行代碼提取復雜 Excel 數據

把 Excel 文件導入關系數據庫是數據分析業務中經常要做的事情&#xff0c;但許多 Excel 文件的格式并不規整&#xff0c;需要事先將其中的數據結構化后再用 SQL 語句寫入數據庫。而一般情況下&#xff0c;結構化的工作量會比較大&#xff0c;而且很難通用&#xff0c;每次都要針…

將一個數組拆分為若干個相等數組

var a [法國,澳大利亞,智利,新西蘭,西班牙,加拿大,阿根廷,美國,0,國產,波多黎各,英國,比利時,德國,意大利,意大利]; var b []; var result []; var k 0; for(var i 0; i<a.length; i){ if(i%3 0){ b []; for(var j 0; j<3; j){ if(a[ij] undefined){ continue; …

人工智能模型的網絡結構可視化

本文主要介紹人工智能模型的網絡結構可視化的常見方法。對于使用神經網絡模型來說&#xff0c;我們主要關注的是模型的輸入和輸出。在 ML.NET 中使用 ONNX 模型時&#xff0c;我們就需要了解這些信息&#xff0c;以便在構成神經網絡的所有層之間生成連接映射。下圖就是昨天 《Y…

Git 撤銷操作 / 回滾歷史

撤銷操作 git checkout -- <filename>&#xff0c;放棄文件的當前更改&#xff0c;回到最近一次的提交狀態git reset HEAD <filename>&#xff0c;取消暫存文件git commit --amend&#xff0c;覆蓋上一次的提交&#xff0c;雖然不是撤銷操作&#xff0c;但有類似的…

整理ASP.NET MVC 5各種錯誤請求[401,403,404,500]的攔截及自定義頁面處理實例

http://2sharings.com/2015/asp-net-mvc-5-custom-404-500-error-hanlde https://blog.csdn.net/yhyhyhy/article/details/51003683 ASP.NET MVC 5的開發中&#xff0c;服務器的各種錯誤[如&#xff1a;401&#xff08;登錄授權驗證&#xff09;&#xff0c;403&#xff08;禁止…

url字符轉義

作者在做短鏈接功能時&#xff0c;url參數里帶了&字符&#xff0c;結果無法轉換。后來查了一下&#xff0c;發現可以用其它符號代替。下面是對應表 URL 中號表示空格 %2B 空格 URL中的空格可以用號或者編碼 %20 / 分隔目…

編輯器領域正發生變革?從面試看 Visual Studio Code 的崛起

Visual Studio Code&#xff08;VS Code&#xff09;的使用率在迅速上升&#xff0c;現在已經成為大多數工程師的首選編輯器&#xff0c;并似乎正迅速搶占其他頂級編輯的市場份額。Triplebyte 每周都會面試數百名工程師。在每次面試中&#xff0c;我們都會記錄面試者使用的編輯…

C#7.0 ref引用傳遞

1.概要在工作中大家用到引用類型是非常多的&#xff0c;大家都知道引用類型在使用過程中傳遞的是對象引用并不會發生整個對象復制。而值類型在傳遞的過程中就不一樣了&#xff0c;我曾經在編寫代碼時希望通過值類型來壓低應用程序的內存占用&#xff0c;在高并發的情況大量的對…

Vue+Axios同步請求

axios本身是沒有同步請求的&#xff0c;要實現同步請求&#xff0c;用到的是ES7的async和await ES7的異步特性async / await async用于聲明一個函數是異步的&#xff0c;await用于聲明在一個異步函數中等待語句執行完畢。也就是說await只能在async函數中使用。簡單示例如下&a…

關于vue執行打包后,如何在本地瀏覽問題

最近一個人在搗鼓vue&#xff0c;寫完項目后發現在npm run dev下可以正常訪問&#xff0c;bulid之后卻一片空白&#xff0c;查看console出現許多Failed to load resource: net::ERR_FILE_NOT_FOUND。恩&#xff0c;看了下網上評論找到了正確的方法 webpack.prod.conf.js 中outp…

ELFhash

字符串哈希算法&#xff08;以ELFHash詳解&#xff09; 更多字符串哈希算法請參考&#xff1a;http://blog.csdn.net/AlburtHoffman/article/details/19641123 先來了解一下何為哈希&#xff1a; 哈希表是根據設定的哈希函數H(key)和處理沖突方法將一組關鍵字映射到一個有限的地…

android面試詳解

前臺就是和用戶交互的進程 可見進程例如一個activity被一個透明的對話框覆蓋&#xff0c;該activity就是可見進程 服務&#xff1a;service進程 后臺一個activity按了home按鍵就是從前臺退回到后臺 標準模式&#xff1a;不管任務棧是否存在相同的activity都會創建一個新的activ…

element-ui Notification重疊問題,原因及解決辦法

在1個方法中調用兩次this.$notify方法&#xff0c;會出現通知框重疊的問題 methods: {checkLogin: function () {if (this.username ) {this.$notify({title: 提示,message: 請輸入用戶名})}if (this.password ) {this.$notify({title: 提示,message: 請輸入用戶密碼})}}}網上…

Visual Stiudio使用技巧

技巧1 自動生成帶參構造函數當我們在編寫代碼時會經常遇到初始化一個的類&#xff0c;需要通過構造函數進行對象初始化。那么這個時候我們可能會需要逐個去手動寫&#xff0c;這樣的工作即重復又無趣。如果是在項目非常緊急的情況下還有大量的字段需要與入參一一對應起來簡直太…

js將時間戳格式化為HH:ii:ss的格式

將時間戳格式化為 HH:ii:ss的格式 <html> <head> </head> <body><span id"time"></span><script>var timestamp Date.parse(new Date())/1000;var time_old Date.parse(new Date())/1000;timeAdd()/*** purpose : …

Struts 整合 SpringMVC

Struts 整合 SpringMVC 過程&#xff1a;這篇文章是我在整合過程中所做的記錄和筆記 web.xml &#xff1a;篩選器機制過濾 原機制是攔截了所有 url &#xff0c;即 <url-pattern>/*</url-pattern>新機制為了將 structs2 的 url 與 SpringMVC 的 url 區分開來&#…

Vue保持用戶登錄及權限控制

vue-router-power-demo 核心內容有兩點&#xff1a; 一是保持用戶登錄狀態&#xff0c;二是根據登錄用戶的角色動態掛在路由 使用vuex保持用戶登錄 點擊登錄按鈕&#xff0c;使用vuex的actions分發登錄操作&#xff0c;發送用戶名和密碼到后臺獲取登錄token&#xff0c; 并存…

java B2B2C Springcloud多租戶電子商城系統-Spring Cloud Sleuth

在微服務框架中&#xff0c;一個由客戶端發起的請求在后端系統中會經過多個不同的的服務節點調用來協同產生最后的請求結果&#xff0c;每一個前段請求都會形成一條復雜的分布式服務調用鏈路&#xff0c;鏈路中的任何一環出現高延時或錯誤都會引起整個請求最后的失敗。 愿意了解…

C#性能測試BenchmarkDotnet

1.簡介在我們開發高性能代碼時&#xff0c;需要各種針對性能優化進行編碼。那么如何才能知道我們所加的代碼是否有性能方面的正向優化呢&#xff1f;有了BenchmarkDotNet&#xff0c;做性能對比測試就非常容易了&#xff0c;只需要把你的測試方法加上特性[Benchmark], 想做不同…