Git入门——分支的基本使用与'合并'、'多人协作'常遇到的问题
2017-05-08 22:41
295 查看
1.基础概念与方法
借用廖雪峰老师的形象的例子:分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习Git的时候,另一个你正在另一个平行宇宙里努力学习SVN。 如果两个平行宇宙互不干扰,那对现在的你也没啥影响。不过,在某个时间点,两个平行宇宙合并了,结果,你既学会了Git又学会了SVN!
一般来说,分支是不仅仅只有主分支的,
master分支是主分支,因此要时刻与远程同步;
dev分支是开发分支,团队所有成员都需要在上面工作,所以也需要与远程同步;
bug分支只用于在本地修复bug,就没必要推到远程了;
feature分支是否推到远程,取决于你是否和你的小伙伴合作在上面开发;
查看分支: git branch 创建分支: git branch (name) 切换分支: git checkout (name) 创建+切换分支: git checkout -b (name) 删除分支: git branch -d (name) 强制删除分支(没合并过的分支可能需要强行删除): git branch -D (name)
2.合并的常见错误
(记得先切换到主分支,然后合并,然后删除’副’分支)合并某分支到当前分支:git merge (branchName)
合并时,两种常见的错误:
1) 通常,合并分支时,如果可能,Git会用fast forward模式
,但这种模式下,删除分支后,会丢掉分支信息。
如果要强制禁用fast forward模式
,Git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息。
–no-ff参数,表示禁用Fast forward
git merge –no-ff -m (“留言”) (name)
2) 冲突,也是合并分支中的常见问题:
(当有两个以上的分支,都commit提交了代码时,合并两个分支可能会产生冲突)
分支合并时,会报出冲突提示,
也可以git status查看,
在文件中,git也会有提示,很直观
(这时候要修改冲突文件,再提交,然后可以查看分支合并情况,再删除分支,保留主分支)
3.多人协作时的麻烦
多人协作时,大家都会往master和dev分支上推送各自的修改所以,这也是常常容易出问题的地方
克隆项目:
git clone git@github.com:PisecesPeng/usegit.git
然后,另台电脑要在dev分支上开发,就必须创建远程origin的dev分支到本地,创建本地分支:
git checkout -b dev origin/dev
开始干活,另台电脑已经向origin/dev分支推送了他的提交,而我也对同样的文件作了修改,并试图推送:
这时,就会推送失败,因为另台电脑的最新提交和我想推送的提交有冲突,
解决办法也很简单,Git已经提示我们,先用git pull把最新的提交从origin/dev抓下来,然后,在本地合并,解决冲突,再推送:
git pull
如果git pull也失败了,原因
b0b8
是没有指定本地dev分支与远程origin/dev分支的链接,根据提示,需设置dev和origin/dev的链接:
git branch --set-upstream dev origin/dev
然后,再来一次git pull
pull成功,但是合并有冲突,需要手动解决,解决的方法和上文中2.的冲突一样。解决!提交!push.
我的Git入门学习,廖雪峰老师的教程帮助了我很多;
也希望能和大家分享一下;
廖雪峰老师的官方网站
相关文章推荐
- Git安装、使用教程、遇到的问题和基本常用命令合集
- git基本使用 创建切换合并分支以及提交本地分支至远程分支
- git基本使用(2)创建切换合并分支以及提交本地分支至远程分支
- git使用笔记3--分支合并与管理
- git使用遇到的问题
- 初级--git及GtiHub初次使用遇到问题自我总结
- Git & Gerrit 使用中遇到的问题
- Git入门篇之环境搭建&基本功能的使用
- git 使用详解(9)-- 分支的新建与合并
- sqlserver 使用中遇到的问题(字符串的合并)
- Arm下使用Qt和Opencv进行图像处理的入门例程和遇到的问题
- git入门四(分支创建合并)
- Git Bash使用中遇到的环境变量的问题
- 免费git服务器以及使用过程中遇到的问题
- git 的使用(5)-git的分支管理以及合并冲突解决
- 使用GIT合并分支: git-merge and git-pull
- 使用Git 过程中遇到的几个问题及其解决方案
- Git入门教程(二):分支的使用
- Android问题集锦转载之七:android的repo和git使用遇到的疑难杂症
- 1git命令的使用,查看git仓库状态,添加文件到git跟踪,git提交,查看git分支,查看git仓库日志信息,切换git分支,解决git分支合并后出现冲突的问题