git fetch和git pull的區(qū)別解析
簡單概括兩者的概念
git fetch是將遠(yuǎn)程主機(jī)的最新內(nèi)容拉到本地,用戶在檢查了以后決定是否合并到工作本機(jī)分支中。
而git pull 則是將遠(yuǎn)程主機(jī)的最新內(nèi)容拉下來后直接合并,即:git pull = git fetch + git merge,這樣可能會產(chǎn)生沖突,需要手動解決。

1.兩者相同點
先在作用上他們的功能是大致相同的,都是起到了更新代碼的作用。
2.不同點
首先我們要說簡單說git的運行機(jī)制。git分為本地倉庫和遠(yuǎn)程倉庫,我們一般情況都是寫完代碼,commit到本地倉庫(生成本地倉的commit ID,代表當(dāng)前提交代碼的版本號),然后push到遠(yuǎn)程倉庫(記錄這個版本號),這個流程大家都熟悉。
我們本地的git文件夾里面對應(yīng)也存儲了git本地倉庫master分支的commit ID 和 跟蹤的遠(yuǎn)程分支orign/master的commit ID(可以有多個遠(yuǎn)程倉庫)。那什么是跟蹤的遠(yuǎn)程分支呢,打開git文件夾可以看到如下文件:
.git/refs/head/[本地分支]
.git/refs/remotes/[正在跟蹤的分支]
其中head就是本地分支,remotes是跟蹤的遠(yuǎn)程分支,這個類型的分支在某種類型上是十分相似的,他們都是表示提交的SHA1校驗和(就是commitID)。但是,不管他們是如何的相似,他們還是有一個重大的區(qū)別:更改遠(yuǎn)端跟蹤分支只能用git fetch,或者是git push后作為副產(chǎn)品(side-effect)來改變。我們無法直接對遠(yuǎn)程跟蹤分支操作,我們必須先切回本地分支然后創(chuàng)建一個新的commit提交。
拉取不同
1、Git fetch:Git fetch會將數(shù)據(jù)拉取到本地倉庫 - 它并不會自動合并或修改當(dāng)前的工作。
2、git pull:git pull是從遠(yuǎn)程獲取最新版本并merge到本地,會自動合并或修改當(dāng)前的工作。
commitID不同
1、Git fetch:使用Git fetch更新代碼,本地的庫中master的commitID不變,還是等于1。
2、git pull:使用git pull更新代碼,本地的庫中master的commitID發(fā)生改變,變成了2。
分支(branch)的基本操作
git branch //查看本地所有分支 git branch -r //查看遠(yuǎn)程所有分支 git branch -a //查看本地和遠(yuǎn)程的所有分支 git branch <branchname> //新建分支 git branch -d <branchname> //刪除本地分支 git branch -d -r <branchname> //刪除遠(yuǎn)程分支,刪除后還需推送到服務(wù)器 git push origin:<branchname> //刪除后推送至服務(wù)器 git branch -m <oldbranch> <newbranch> //重命名本地分支 /** *重命名遠(yuǎn)程分支: *1、刪除遠(yuǎn)程待修改分支 *2、push本地新分支到遠(yuǎn)程服務(wù)器 */ //git中一些選項解釋: -d --delete:刪除 -D --delete --force的快捷鍵 -f --force:強(qiáng)制 -m --move:移動或重命名 -M --move --force的快捷鍵 -r --remote:遠(yuǎn)程 -a --all:所有
3.git fetch用法
git fetch 命令:
$ git fetch <遠(yuǎn)程主機(jī)名> //這個命令將某個遠(yuǎn)程主機(jī)的更新全部取回本地
如果只想取回特定分支的更新,可以指定分支名:
$ git fetch <遠(yuǎn)程主機(jī)名> <分支名> //注意之間有空格
最常見的命令如取回origin 主機(jī)的master 分支:
$ git fetch origin master
取回更新后,會返回一個FETCH_HEAD ,指的是某個branch在服務(wù)器上的最新狀態(tài),我們可以在本地通過它查看剛?cè)』氐母滦畔ⅲ?/p>
$ git log -p FETCH_HEAD

可以看到返回的信息包括更新的文件名,更新的作者和時間,以及更新的代碼(19行紅色[刪除]和綠色[新增]部分)。
我們可以通過這些信息來判斷是否產(chǎn)生沖突,以確定是否將更新merge到當(dāng)前分支。
4.git pull 用法
前面提到,git pull 的過程可以理解為
git fetch origin master //從遠(yuǎn)程主機(jī)的master分支拉取最新內(nèi)容 git merge FETCH_HEAD //將拉取下來的最新內(nèi)容合并到當(dāng)前所在的分支中
即將遠(yuǎn)程主機(jī)的某個分支的更新取回,并與本地指定的分支合并,完整格式可表示為:
$ git pull <遠(yuǎn)程主機(jī)名> <遠(yuǎn)程分支名>:<本地分支名>
如果遠(yuǎn)程分支是與當(dāng)前分支合并,則冒號后面的部分可以省略:
$ git pull origin next
5.拉取遠(yuǎn)程分支
git fetch //代碼拉取到本地之后 git branch //查看分支 git checkout 遠(yuǎn)程分支的分支名
參考文章
https://blog.csdn.net/qq_36113598/article/details/78906882
https://blog.csdn.net/weixin_41975655/article/details/82887273
到此這篇關(guān)于git fetch和git pull的區(qū)別的文章就介紹到這了,更多相關(guān)git fetch和git pull的區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vscode 左側(cè)擴(kuò)展活動欄內(nèi)容消失的問題及解決方法
vscode左側(cè)活動欄默認(rèn)會有 一些內(nèi)容,今天一不小心,不知道怎么的,將部分內(nèi)容搞沒了,vscode 左側(cè)擴(kuò)展活動欄內(nèi)容消失了怎么辦,下面給大家分享本文幫助大家快速解決,感興趣的朋友一起看看吧2021-08-08
如何用idea+gitee來團(tuán)隊合作開發(fā)項目的教程
這篇文章主要介紹了如何用idea+gitee來團(tuán)隊合作開發(fā)項目,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08
五步完成unity與微信(游戲)小程序交互創(chuàng)建視頻
這篇文章主要介紹了unity與微信(游戲)小程序交互創(chuàng)建視頻的步驟,非常簡單,只需要五步就可完成,有需要的朋友可以借鑒參考下,希望可以有所幫助2021-09-09
虛擬主機(jī)下實現(xiàn)多域名綁定不同的子目錄的方法
虛擬主機(jī)域名綁定子目錄asp php html (通用)2010-03-03
VSCode如何遠(yuǎn)程連接Linux教程(密鑰的使用)
本文主要介紹了VSCode如何遠(yuǎn)程連接Linux教程,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12

