[git]Git的使用流程(三)
来源:互联网 发布:手机淘宝客采集软件 编辑:程序博客网 时间:2024/05/18 13:07
摘要:git的分支功能
关键词:分支;多人协作。
创建简单分支
分支管理(branch)是git的重要功能,可以用交通上的行车来类比。主分支类似于主干道,名为master。分支管理的过程可以看做:一部分车流因任务需要从主干道上离开,前往分支干道上完成任务,然后再回到主干道。从主干道上离开前往分支干道,为创建分支;完成任务后回到主干道,为合并分支。这种只有一次分支的情况是简单分支,是分支管理的基础情况。简单分支操作步骤为:
0.先查看目前所在的分支,指令为:git branch 。分支名前的星号标记当前工作分支,新建的仓库一般只有一个名为master的分支。
1.通过指令:git checkout -b dev ,创建一个新的分支'dev’,'-b’的意义是创建分支的同时工作分支也会切换到dev上。
2.在文件夹中新建一个learnBranch.txt 文本。然后输入指令:git add learnBranch.txt 和 git commit -m 'new branch‘,将文本提交到版本库。如果这时候再输入指令:git checkout master,将工作分支切换到master,可以发现文件夹中的learnBranch.txt文本消失了,说明master的版本库和dev的版本库是不同的。
3.现在假设分支dev的工作完成了,需要将其合并回主分支master,并将失去作用的分支dev删除。
(1)先切换回主分支master:git checkout master
(2)将分支dev的工作成果合并到master上:git merge dev
(3)删除dev分支:git branch -d dev (即用-d表示删除)
git与GitHub在分支上的联动
1.在本地git上创建的分支,如dev,可以通过指令:git push origin dev,将新分支推送到GitHub即可更新新的分支。
2.在本地完成工作后,分支dev合并到master,并删除dev。此时:git push origin master 可以将工作成果更新到GitHub。
3.但会发现虽然在本地上删除了dev,但GitHub上还是有着dev分支的,而此时已经不能用 git push origin dev 了,因为dev已经被删除。正确做法是 git push origin --delete dev 或者 git push origin :dev 。其中后者语句的意义是推送一个空的分支到远程的dev分支,所以也是删除远程的dev分支。
4.如果在远程删除了一个不再需要分支,要在本地上删除,指令为:gti remote prune origin。
(注:本地仓库做出的改动和记录都会在GitHub上留下记录。但分支被删除时记录也被删除,最后之只留下master的记录)
分支上的冲突
分支上的冲突一般是指合并master与dev时git发现两个仓库本应相同的地方出现了差别,导致合并分支不能进行下去。
例如,创建dev分支后更改了文件的全部内容:
master分支的文本:this is master
dev分支的文本:this is dev
git add 并git commit -m '',然后切回master分支并 git merge dev时会报错(因为不同无法合并),点击文件发现文件已经被git改变成这个样子:
<<<<<<< HEAD
this is master
=======
this is dev
>>>>>>> dev
(注:这时候已经不能再在dev和master间切换分支了,因为git正在等待你将文本间的差异修正,然后合并分支)
这时应该把这一片段的文本改成你所希望的样子,然后git add 和git commit -m ' ',git就会按你的修改修正文本间的差异然后自动合并分支。
输入指令git log --graph --pretty=oneline --abvert-commit
可以查看这一部分的操作日志。
临时分支
假设现在有主分支master和分支dev,正在分支dev上工作且工作还未提交时,接到新任务,要创建一个临时分支issue去完成任务。这时候如果直接创建并切换到新的分支issue,会导致分支dev上的工作丢失。所以需要通过在dev分支上执行指令:git stash,将dev分支上的工作冻结起来。待新任务完成后,再次回到dev分支时,通过执行指令:git stash pop解冻。(或者git stash apply 然后 git stash drop)
强制删除
假设上一个情境中,新任务最后被取消,所以临时分支issue要删除。但在输入指令:git branch -d issue后会报错,因为临时分支并未被合并。这时候(先切换到其他分支,因为不能再issue分支上删除issue自己) 要通过指令强制删除临时分支:git branch -D issue 。
多人协作
0.在GitHub上完成多人协作的任务,在分支dev上工作。合作者从远程仓库‘origin'上clone到本地仓库时,默认只能得到master分支。要创建远程仓库origin的dev分支到本地,需要执行命令:git checkout -b dev origin/dev 。
1.多人合作时,不同人的dev肯定是不一样的。所以在执行:git push origin dev时遇到失败很正常,因为dev已经被合作者更新过了,需要将新版本的dev与本地的合并。
2.先创建本地dev分支与远程origin/dev分支的链接(否则git pull会失败):git branch --set-upstream dev origin/dev 。
3.然后执行git pull ,把最新的origin/dev抓取下来,在本地合并后再推送更新origin/dev。
(图片来源:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013758410364457b9e3d821f4244beb0fd69c61a185ae0000)
所以,在最后,多人协作的分支情况如上。每个人在自己的分支上工作,然后把工作成果更新到dev上,最后在合并到master上。
- [git]Git的使用流程(三)
- [git]Git的使用流程(一)
- [git]Git的使用流程(二)
- [git]Git的使用流程(四)
- Git的使用三:多人开发流程
- Git的一次使用流程
- 初学者的git使用流程
- git的日常使用流程
- git的基本使用流程
- [git]Git使用流程(五)
- git的使用之三
- Git的使用(三)
- git的使用以及git的写作流程
- git使用流程
- git使用基本流程
- Git 使用规范流程
- Git 使用规范流程
- Git 使用规范流程
- 1.3 C# 循环语句
- HDU
- 设置spinner选项选择后变成灰色
- Git的一些简单操作
- Lightoj1021Painful Bases (状压DP)
- [git]Git的使用流程(三)
- 3运算符
- logstash kafka多台机器取数据,只有一个实例消费
- MPLS VPN知识
- Java面向对象3
- 初学java--数据类型介绍
- eclipse安装、JDK安装、环境变量配置
- HDU
- Leetcode204.Count Primes