敏捷开发系列学习总结(5)——这几招搞定团队协同Coding
一个团队在一起Coding时,就怕发生这样的事情:同1个文件你改了,我也改了,他也改了,最后怎么同步呢?以前用clearcase时,A把文件checkout了,其他人就不能提交,保证了代码的唯一性。但现在用git后,大家都可把文件拉到本地库,修改完后提交到远程库。现在发生A、B、C三人都修改了某个文件后,代码怎么同步呢?
1、 git分支
利用git,一个团队可以协同工作。但怎么保证团队人员之间互不冲突呢?这就需要用分支。
⑴ master分支是非常稳定的,只用来发布新版本,平时不能在上面干活。
⑵ dev分支是不稳定的,干活都在dev分支上进行。比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;
⑶ 团队里的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。
用Sourcetree进行分支操作:
⑴ 分支
① 点击“分支”。
② 在弹出框中输入新分支,比如dev,然后点“创建分支”确认。
③ dev分支创建成功
④ 选择“当前分支”,这样只会显示当前分支相关的信息。
⑵ 合并
比如要把dev合并到master分支。
① 切换到master分支,选择dev分支,点击鼠标右键,弹出框框。
② 点击“合并dev至当前分支”
用git命令进行分支操作:
① 查看分支:git branch
② 创建分支:git branch name
③ 切换分支:git checkout name
④ 创建+切换分支:git checkout -b name
⑤ 合并某分支到当前分支:git merge name
⑥ 删除分支:git branch -d name
2、git冲突
产生冲突的方式很多,常见的一种是创建一个分支并修改提交,然后回到主分支再修改提交同一个文件,然后“合并分支”就发生冲突。
比如:
⑴
这里提示 testwork.php文件在合并时发生了冲突。
⑵ 打开testwork.php。
<<<<<<< HEAD 表示主分支,主分支的修改是:
test1
Test12223
;
>>>>>>dev表示创建的dev分支,dev分支的修改是:
test133
test122
⑶ 人工修改
你只要人工修改testwork.php就可以了,比如你希望testwork.php最后是这样的:
然后再次在master分支commit就可以了。
敏捷开发系列学习总结(5)——这几招搞定团队协同Coding的更多相关文章
- 14招搞定JavaScript调试
		
14招搞定JavaScript调试 译者按: 很多时候,大家可能只是依靠console.log来调试JavaScript代码,这样做的局限性不言而喻,这篇博客将教你几招实用的调试技巧. 原文: The ...
 - 敏捷开发系列学习总结(4)—Git管理工具sourcetree的安装
		
现在代码管理都流行用git了,小编以前用过clearcase, svn,vss等.现在用了git后,发现git才是最好的,我觉得它最吸引人的地方应该是它的分布式管理吧.git的具体学习,读者可自己去网 ...
 - 敏捷开发系列学习总结(2)——Bug修改流程
		
原则,力求各司其职,简单明了. 1. 测试人员提交bug ⑴ 标题: [ 模块名称 ] 问题描述 ⑵ 内容: 问题重现步骤的描述,最好贴上图片. 因为一图胜万言. ⑶ 指定责任人: 根据bug指定责任 ...
 - 10招搞定web设计风格指南
		
From:http://www.ui.cn/detail/27579.html 今时今日,网站的创建正变得越来越复杂,而且一般都不是一个人就能干的了的.在创建网站过程中,我们需要保证设计前后一致,并符 ...
 - 一招搞定多Offer选择
		
12月9号在论坛看到一位毕业生问了一个问题: 如今两个offer 一个在南京,搞.net ,公司是国电南自.税前一年加起来几乎相同7.2万.一个是在上海.搞java,公司名叫鑫合汇(不知道各位有没实用 ...
 - Python基于VS2013 开发环境搭建 Hello World 10分钟搞定
		
1.先下载Python 安装 Next ->安装完成 2.以前安装过VS2013 打开VS2013 文件->新建项目 (此时如果没有Python Application,请点击里面的安装插 ...
 - 3年java开发面试BAT,你必须彻底搞定Maven!
		
前言 现在的Java项目中,Maven随处可见. Maven的仓库管理.依赖管理.继承和聚合等特性为项目的构建提供了一整套完善的解决方案,如果你搞不懂Maven,那么一个多模块的项目足以让你头疼,依赖 ...
 - 新能力 | 云开发CMS内容管理系统,5分钟搞定小程序管理后台
		
小程序·云开发的云调用能力,让用户可以免鉴权快速调用微信的开放能力,极大节约了开发成本.现在,大家期待已久的云开发 CMS 内容管理系统,终于上线啦!顺便提示,接下来还可以二次开发哦! 云开发 CMS ...
 - iOS 一招搞定去掉字符串开始的0,尤其是针对时间格式化
		
// 2.利用整型自动去掉开头的0, 不要循环和判断prefix以及截取字符串- (NSString *)pp_formatDateWithArrYMDToMD;{ NSInteger mont ...
 
随机推荐
- jsp注释前台不可见
			
<%-- <div class="content"></div> --%>
 - JSP-Runoob:JSP 调试
			
ylbtech-JSP-Runoob:JSP 调试 1.返回顶部 1. JSP 调试 要测试/调试一个JSP或servlet程序总是那么的难.JSP和Servlets程序趋向于牵涉到大量客户端/服务器 ...
 - hibernate基础学习---hierbnate2级缓存
			
1:开启二级缓存sessionFactory需要安装jar包 2:在实体类配置文件添加(配置二级缓存).我的配置文件是Account.hbm.xml <?xml version="1. ...
 - maven+ssm+oracle实现简单的增删改查
			
首先看一下项目结构 第一步先导入jar包 pom.xml <properties> <spring.version>4.3.18.RELEASE</spring.vers ...
 - JavaScript--提问(prompt 消息对话框)
			
prompt弹出消息对话框,通常用于询问一些需要与用户交互的信息.弹出消息对话框(包含一个确定按钮.取消按钮与一个文本输入框). 语法: prompt(str1, str2); 参数说明: str1: ...
 - 对于民科吧s5_or吧友自增树的复杂度计算
			
原帖 自增树如s5_or所说,是一种思想像Splay的数据结构,每个节点维护一个堆权值,每当询问一个节点时,堆权值++,并返回时维护堆权值为堆的性质.这个树从旋转次数上比Splay小是肯定的,因为Sp ...
 - ACM_三角形蛇形矩阵
			
三角形蛇形矩阵 Time Limit: 2000/1000ms (Java/Others) Problem Description: 小铠觉得各类题型是要温故而知新的,所以他叫小发出一道类似做过的题. ...
 - 【Leetcode】115. Distinct Subsequences
			
Description: Given two string S and T, you need to count the number of T's subsequences appeared in ...
 - T-SQL查询基础
			
今天来带大家了解下在sql server 中的查询机制 使用select语句进行查询 1.查询所有的数据行和列 select * from student 2.查询部分行和列 select scode ...
 - Ajax应用查询员工信息
			
首先要用上一篇的步骤启动服务器,建立站点.然后在该站点下创建php文件和html文件. php代码如下,文件名为server.php <?php //设置页面内容是html编码格式是utf-8 ...