tft每日頭條

 > 生活

 > git分支是幹啥的

git分支是幹啥的

生活 更新时间:2025-02-02 02:43:05

不知道大家有沒有經曆過,當我們切換到了一個新的分支想要提交代碼的時候,總會遇到這樣的錯誤。

git分支是幹啥的(git的遠程分支是幹啥的)1

我們把日志裡的英文翻譯過來是說,我們當前的分支沒有設置任何上遊分支。然後git提示我們可以運行下面這行代碼來設置遠程的上遊,這樣我們就可以push成功了。

當然如果我們push的時候執行的不是git push,而是後面再加上origin的話,就可以push成功了。比如這樣:

git分支是幹啥的(git的遠程分支是幹啥的)2

那麼這是什麼原因呢?這個origin分支又是什麼意思呢?我們今天就來讨論一下這個問題。

遠程分支

遠程分支其實就是遠程代碼倉庫當中的分支,比如我們的repo如果是存在github的,那麼這個遠程倉庫就是github,如果是存在gitlab的,那麼這個倉庫就是gitlab,如果是其他的倉庫也是一樣的道理。

當我們在使用git clone的時候,git會自動地将這個遠程的repo命名為origin,拉取它所有的數據之後,創建一個指向它master的指針,命名為origin/master,之後會在本地創建一個指向同樣位置的指針,命名為master,和遠程的master作為區分。

也就是說,origin的含義指的是遠程的倉庫。它隻是一個标記,就和默認分支叫做master一樣,本身并沒有特别的含義。如果我們願意也可以起其他的名字,但是一般沒有人這麼幹。比如我們在clone的時候可以添加一個參數-o給遠程的repo起一個别名:

gitclone-ochengzhi

這樣一來,遠程的這個repo就會被命名為chengzhi,代替原本的origin。但是這樣除了裝逼和增加成本之外,沒有任何用處,不推薦這麼幹。

操作命令

還記得我們之前在介紹git的時候曾經說過遠程repo的作用,就是為了防止本地的代碼錯亂,所以在遠程留一份備份。這樣即使我們的代碼完蛋了,至少還可以找到備份。

所以遠程的repo最大的作用就是保留備份,既然要保留備份,那麼我們本地和遠程的代碼交互肯定是免不了的。大家可能都大概知道git pull從遠程拉取,git push推送到遠程,但是對于這其中的細節可能不太清楚。之前沒有詳細介紹過遠程分支,所以也沒辦法深入,我們今天剛好聊到這個話題,正好好好說道說道。

代碼拉取

我們先說代碼拉取,說到代碼拉取大家的第一反應可能是git pull。但是其實git pull并不是嚴格意義上的代碼拉取命令,至少它還不是最細粒度,其實還有一個比git pull更加細粒度的操作。它就是——git fetch。

實際上git fetch才是真正的代碼拉取的操作,它的作用是将遠程的改動同步到本地。當我們執行git fetch origin的時候,這裡的origin指的是遠程的名字,如果你有多個遠程的話要指定的話需要加上,否則可以不寫。它會把遠程所有的改動和分支都拉取到本地,命名為origin/xxx。origin的分支我們用git branch是看不到的,它隻能看到本地的分支名,如果想要查看可以使用git branch -r。

當我們使用git checkout切換過去的時候,可以不必加上origin,git會自動生成一個本地的分支指針,也指向同樣的節點。它相當于我們執行了git checkout -b test origin/test。說到這裡就需要提一下git pull和git fetch的區别了,這兩者從表面上來看都是拉取遠程的改動。但是兩者針對的範圍不同,git fetch針對遠程的所有改動,而git pull隻針對當前分支對應的遠程分支。另外git pull執行之後會将遠程的改動merge到本地的分支,也就是說它其實多了一步merge的操作。

代碼推送

說到代碼推送回到了我們開頭的那個問題,什麼情況下git push就可以,什麼情況下需要加上origin呢?

這裡涉及一個機制就是本地的分支是不會自動和遠程同步的,比如遠程有人創建了一個test分支,我們拉取到本地會叫做origin/test。我們也可以自己創建一個test分支,和它井水不犯河水。這也是為了方便,如果直接用名稱映射的話,可能會有潛在的沖突。并且由于可能會存在多個遠程repo,所以我們push的時候也會有多種選擇。

最完整的push命令是應該寫成這樣的:

gitpushorigintest:cz/test

我們注意到這裡用了一個奇怪的寫法test:cz/test,它的意思是說将本地的test分支推送到遠程作為cz/test分支。如果我們想要本地的名稱和遠程一樣,我們可以省略簡寫成:git push origin test。

如果我們設置過當前test分支的上遊是遠程的test,或者本地的test就是從origin拷貝過來的,那麼我們可以直接git push,它會自動将本地的分支與遠程關聯上,會方便很多。實際上我們大多數的push操作都是這麼進行的。将本地分支和遠程建立映射可以使用這個命令:

gitbranch--set-upstream-tomasterorigin/master

它表示的是将本地的master和遠程的master進行關聯,設置過關聯之後我們隻需要git push和git pull就可以更新和推送這個分支了,會方便很多。

關于遠程分支還有一些内容我們沒有涉及,比如如何跟蹤遠程的分支,如何删除等等。由于這些内容幾乎用不到,我們即使強行記住了到時候也會忘記,所以就不多贅述了。

今天的文章就到這裡,衷心祝願大家每天都有所收獲。如果還喜歡今天的内容的話,請來一個三連支持吧~(點贊、關注、轉發

- END -

本文始發于公衆号:TechFlow,求個關注

,

更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!

查看全部

相关生活资讯推荐

热门生活资讯推荐

网友关注

Copyright 2023-2025 - www.tftnews.com All Rights Reserved