git pull 和 git fetch 的区别你知道吗?

git pullgit fetch是什么

  • git fetch 命令用于从另一个存储库下载对象和引用
  • git pull 命令用于从另一个存储库或本地分支获取并集成

当远端仓库里有新的内容时,就要使用到git pull或者git fetch命令把新的内容下载下来。

git fetch是将远程主机的最新内容拉到本地,用户在检查了以后决定是否合并到工作本机分支中。而git pull 则是将远程主机的最新内容拉下来后直接合并 ,即:git pull = git fetch + git merge,这样可能会产生冲突,需要手动解决

在我们本地的git文件中对应也存储了git本地仓库分支的commit ID和 跟踪的远程分支的commit ID,对应文件如下:

  • .git/refs/head/[本地分支]
  • .git/refs/remotes/[正在跟踪的分支]

使用 git fetch更新代码,本地的库中mastercommitID不变,但是与git上面关联的那个orign/mastercommit ID发生改变。这时候我们本地相当于存储了两个代码的版本号,我们还要通过merge去合并这两个不同的代码版本。也就是fetch的时候本地的master没有变化,但是与远程仓关联的那个版本号被更新了,接下来就是在本地merge合并这两个版本号的代码。

使用git pull就会直接将本地的代码更新至远程仓库里面最新的代码版本。

用法

git fetch

git fetch用法如下:

xml 复制代码
git fetch <远程主机名> <远程分支名>:<本地分支名>

例如从远程的origin仓库的master分支下载代码到本地并新建一个temp分支

sql 复制代码
git fetch origin master:temp

git pull

两者的用法十分相似,git pull用法如下:

xml 复制代码
git pull <远程主机名> <远程分支名>:<本地分支名>

例如将远程主机originmaster分支拉取过来,与本地的branchtest分支合并,命令如下:

复制代码
git pull origin master:branchtest

同样如果上述没有冒号,则表示将远程origin仓库的master分支拉取下来与本地当前分支合并。

区别

相同点:

  • 在作用上他们的功能是相同的,都是起到了更新代码的作用。

不同点:

  • **git pull是相当于从远程仓库获取最新版本,然后再与本地分支merge,**即git pull = git fetch + git merge
  • git fetch更安全,在merge前,我们可以查看更新情况,根据实际情况再决定是否合并。
相关推荐
骆驼爱记录14 小时前
Word侧边页码设置全攻略
前端·自动化·word·excel·wps·新人首发
方安乐14 小时前
react笔记之useCallback/useEffect闭包陷阱
前端·笔记·react.js
沐墨染14 小时前
黑词分析前端组件设计:双面板交互与黑词进度监控
前端
运维行者_15 小时前
用Applications Manager监控HAProxy:保障负载均衡高效稳定
运维·开发语言·前端·数据库·tcp/ip·负载均衡·服务器监控
东东51617 小时前
基于ssm的网上房屋中介管理系统vue
前端·javascript·vue.js
harrain18 小时前
什么!vue3.4开始,v-model不能用在prop上
前端·javascript·vue.js
fanruitian1 天前
uniapp android开发 测试板本与发行版本
前端·javascript·uni-app
rayufo1 天前
【工具】列出指定文件夹下所有的目录和文件
开发语言·前端·python
RANCE_atttackkk1 天前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
2501_944525541 天前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter