git命令使用(二)

拉取分支

我们需要:git fetch origin dev 命令来把远程分支拉到本地

然后使用:git checkout -b dev origin/dev在本地创建分支dev并切换到该分支

最后使用:git pull origin dev就可以把某个分支上的内容都拉取到本地


查看分支:git branch

创建分支:git branch <name>

切换分支:git checkout <name>

创建+切换分支:git checkout -b <name>

合并某分支到当前分支:git merge <name>

删除分支:git branch -d <name>

查看当前分支

$git branch
  *dev
  master

切回主干

$git checkout master
Switched to branch 'master'
Your branch is up-to-date with 'origin/master'

将分支合并到主干

git merge命令用于合并指定分支到当前分支。

CONFLICT (modify/delete):
…
Auto-merging 
…
Fast-forward

Fast-forward信息,Git告诉我们,这次合并是“快进模式”,也就是直接把master指向dev的当前提交,所以合并速度非常快。当然,也不是每次合并都能Fast-forward。


删除dev分支

合并完成后,就可以删除dev分支

$git branch -d dev
Deleted branch dev (was fec145a).
若分支中修改了一个文件A.java ,主干中也修改了这个文件,当进行合并时; 这种情况下,Git无法执行“快速合并”,只能试图把各自的修改合并起来,但这种合并就可能会有冲突
$ git merge feature1
Auto-merging readme.txt
CONFLICT (content): Merge conflict in readme.txt
Automatic merge failed; fix conflicts and then commit the result.
Git告诉我们,readme.txt文件存在冲突,必须手动解决冲突后再提交。git status也可以告诉我们冲突的文件:

$ git status
On branch master
Changes to be committed:
        modified:   **nfo.java
        modified:   **dInfo.java     
Unmerged paths:
        both modified:  ***tants.java
        added by us:   
        deleted by us:

查看红色的文件


<<<<<<< HEAD:tants.java
    String NO_DATA_CODE = "100000";
    String NO_DATA_MESSAGE = "操作数据不存在";
=======
<<<<<<< ======= >>>>>>> 标记出不同分支的内容,修改后保存

再提交:

$ git add ***stants.java 
$ git commit -m "conflict fixed"
再看改文件,变为蓝色的了。

Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。

git log --graph命令可以看到分支合并图


用带参数的git log看分支的合并情况

$ git log --graph --pretty=oneline --abbrev-commit
*   59bc1cb conflict fixed
|\
| * 75a857c AND simple
* | 400b400 & simple
|/
* fec145a branch test
...

在实际开发中,我们应该按照几个基本原则进行分支管理:

首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;

那在哪干活呢?干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;

你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。

所以,团队合作的分支看起来就像这样:


合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。




Head ,

当我们创建新的分支,例如dev时,Git新建了一个指针叫dev,指向master相同的提交,再把HEAD指向dev,就表示当前分支在dev


Git创建一个分支很快,因为除了增加一个dev指针,改改HEAD的指向,工作区的文件都没有任何变化,从现在开始,对工作区的修改和提交就是针对dev分支了,比如新提交一次后,dev指针往前移动一步,而master指针不变


我们在dev上的工作完成了,就可以把dev合并到master上。Git怎么合并呢?最简单的方法,就是直接把master指向dev的当前提交,就完成了合并


合并完分支后,甚至可以删除dev分支。删除dev分支就是把dev指针给删掉,删掉后,我们就剩下了一条master分支了。

git add ** file

git commit -m '**'

git push -u origin master



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值