石家庄有做网站的公司吗,学生兼职网站开发,网站建设授权书,优秀 网站设计 蓝色1、简单概括 先用一张图来理一下git fetch和git pull的概念#xff1a;
可以简单的概括为#xff1a;
git fetch是将远程主机的最新内容拉到本地#xff0c;用户在检查了以后决定是否合并到工作本机分支中。
而git pull 则是将远程主机的最新内容拉下来后直接合并#x…1、简单概括 先用一张图来理一下git fetch和git pull的概念
可以简单的概括为
git fetch是将远程主机的最新内容拉到本地用户在检查了以后决定是否合并到工作本机分支中。
而git pull 则是将远程主机的最新内容拉下来后直接合并即git pull git fetch git merge这样可能会产生冲突需要手动解决。
下面我们来详细了解一下git fetch 和git pull 的用法。 2、分支的概念 在介绍两种方法之前我们需要先了解一下分支的概念 分支是用来标记特定代码的提交每一个分支通过SHA1sum值来标识所以对分支的操作是轻量级的你改变的仅仅是SHA1sum值。
如下图所示当前有2个分支A,C,E属于master分支而A,BD,F属于dev分支。
A----C----Emaster \ B---D---F(dev) 它们的head指针分别指向E和F对上述做如下操作
git checkout master //选择or切换到master分支 git merge dev //将dev分支合并到当前分支(master)中 合并完成后
A---C---E---G(master) \ / B---D---Fdev 现在ABCDEFG属于masterG是一次合并后的结果是将E和的代码合并后的结果可能会出现冲突。而ABDF依然属于dev分支。可以继续在dev的分支上进行开发:
A---C---E---G---H(master) \ / B---D---F---Idev 分支branch的基本操作
git branch //查看本地所有分支
git branch -r //查看远程所有分支
git branch -a //查看本地和远程的所有分支
git branch branchname //新建分支
git branch -d branchname //删除本地分支
git branch -d -r branchname //删除远程分支删除后还需推送到服务器 git push origin:branchname //删除后推送至服务器
git branch -m oldbranch newbranch //重命名本地分支 /** *重命名远程分支 *1、删除远程待修改分支 *2、push本地新分支到远程服务器 */
//git中一些选项解释:
-d --delete删除
-D --delete --force的快捷键
-f --force强制
-m --move移动或重命名
-M --move --force的快捷键
-r --remote远程
-a --all所有 3、git fetch 用法 git fetch 命令
$ git fetch 远程主机名 //这个命令将某个远程主机的更新全部取回本地 如果只想取回特定分支的更新可以指定分支名
$ git fetch 远程主机名 分支名 //注意之间有空格 最常见的命令如取回origin 主机的master 分支
$ git fetch origin master 取回更新后会返回一个FETCH_HEAD 指的是某个branch在服务器上的最新状态我们可以在本地通过它查看刚取回的更新信息
$ git log -p FETCH_HEAD 如图 可以看到返回的信息包括更新的文件名更新的作者和时间以及更新的代码19行红色[删除]和绿色[新增]部分。
我们可以通过这些信息来判断是否产生冲突以确定是否将更新merge到当前分支。 4、git pull 用法 前面提到git pull 的过程可以理解为
git fetch origin master //从远程主机的master分支拉取最新内容 git merge FETCH_HEAD //将拉取下来的最新内容合并到当前所在的分支中 即将远程主机的某个分支的更新取回并与本地指定的分支合并完整格式可表示为
$ git pull 远程主机名 远程分支名:本地分支名 如果远程分支是与当前分支合并则冒号后面的部分可以省略
$ git pull origin next