git分支提交管理
随着需求的增多,为了多人协作的顺利进行,需要进行分支开发,进而带来分支管理问题。今天主要讲一下如何管理分支及提交。
为了使git更好用,下面是我的git配置文件(放在C:\Users\Administrator目录下的.gitconfig文件)。
[user]
email = xxx
name = xxx
[gui]
encoding = UTF-8
[core]
autocrlf = false
[color]
ui = auto
[branch]
autosetuprebase = always
[alias]
st = status
ci = commit
co = checkout
br = branch
rb = reset --hard ORIG_HEAD
unstage = reset HEAD
lg = log --graph --oneline --decorate
last = log --graph --oneline --decorate origin/master..HEAD
[diff]
external = ~/meld.sh
这样就可以简化命令了,比如 git status 可以简化为 git st ,另外,git lg 查看log的时候格式也更加好看了,并且 git diff 查看文件改动对比更加明了。
要想使用git diff,还需要一点点配置:
下载meld,配置git如下:
$ git config --global diff.external ~/meld.sh
编写 meld.sh 包装脚本:
$ vim ~/meld.sh
内容如下:
#!/bin/sh
meld $ $
写了这么多无关话题,现在说正题。
在进行分支提交管理的时候使用最多的2条命令是rebase -i和cherry-pick。
rebase -i 用来合并多个commit为1个,cherry-pick用来拾取commit。现在举例说明。
首先示例rebase -i来合并多个commit。
1、查看当前分支提交记录

2、在当前分支新建test分支

3、在test分支提交3次

4、现在要把test分支的3个提交合并到dev,不推荐使用merge,因为会使log分支,推荐使用rebase来合并,所有的log都在一条线上。所以现在切回dev,然后git rebase test即可。


5、此时如果想把第二三四个提交合并为1个,就rebase -i到第一个提交。
运行以下命令:
git rebase -i add92ec
此时弹出:

根据命令提示,把下面2个pick改为s后wq保存退出:

此时弹出提交汇总,可直接保存退出:

此时rebase -i成功:

可以看到第二三四个提交都合并为第二个提交。
详细提交记录:

所以rebase -i主要是为了保持主分支的整洁性。
cherry-pick来拾取,比如,我们可以把test分支的第三个提交取到dev分支来,不需要第二和第四个提交。
1、首先dev分支回到第一个提交:

2、查看test分支第三个提交的版本号

3、回到dev分支来拾取test分支的第三个提交

运气不好,发生了冲突,所以失败了,那就解决冲突后继续:
git st查看,得知冲突文件,解决冲突后continue。

现在test分支的第三个提交就到dev分支来了。
两个git进阶命令,很实用的哦,你学会了么,嘿嘿嘿。
git分支提交管理的更多相关文章
- Git分支高级管理[四]
标签(linux): git 笔者Q:972581034 交流群:605799367.有任何疑问可与笔者或加群交流 切换分支 git checkout 撤销对文件的修改 git checkout -- ...
- Git 分支代码管理日记备注
1〉 Bithucket 创建代码库 2〉 下载克隆代码 Git clone 代码链接 3〉 代码初始化完成之后,切换到代码文件夹 cd 文件夹名 4〉 查看分支情况 Git brach 5〉 ...
- Git分支的管理
(一)查看分支 1.查看本地分支:git branch 2.查看远程分支:git branch -r 3.查看所有分支:git branch -a (二)创建分支 1.创建本地分支:git branc ...
- Git分支管理及常见操作
众所周知,使用Git分支,我们可以从开发主线上分离开来,然后在不影响主线的同时继续工作. 既然要使用Git分支,这里就涉及到Git分支的管理及常见操作,如列出分支,分支的创建,分支的删除,分支的合并等 ...
- 【代码管理】GitHub超详细图文攻略 - Git客户端下载安装 GitHub提交修改源码工作流程 Git分支 标签 过滤 Git版本工作流
GitHub操作总结 : 总结看不明白就看下面的详细讲解. . 作者 :万境绝尘 转载请注明出处 : http://blog.csdn.net/shulianghan/article/details ...
- GIT分支管理模型
GIT分支管理模型 link: git-branching-model 主分支(Main branches) 项目两个常驻分支: master 主干分支(锁定),仅用于发布新版本,平时不能在上面干活, ...
- Git 分支管理是一门艺术
转载: Git 分支管理是一门艺术 1 要确保:团队成员从主分支(master)获得的都是处于可发布状态的代码,而从开发分支(develop)应该总能够获得最新开发进展的代码. 2 "辅助分 ...
- GitHub超详细图文攻略 - Git客户端下载安装 GitHub提交修改源码工作流程 Git分支 标签 过滤 Git版本工作流
最近听同事说他都在使用GitHub,GitHub是程序员的社区,在里面可以学到很多书上学不到的东西,所以最近在准备入手这方面的知识去尝试学习,正好碰到这么详细完整的文章,就转载了,希望对自己和大家有帮 ...
- Git 分支管理详解
大纲: 1.前言 2.创建分支 3.切换分支 4.合并分支(快速合并) 5.删除分支 6.分支合并冲突 7.合并分支(普通合并) 8.分支管理策略 9.团队多人开发协作 10.总结 注,测试机 Cen ...
随机推荐
- 有奖试读&征文——我们在互联网上奋斗的故事 获奖名单发布
互联网是一个年轻的行业,同一时候也是一个推陈出新.不断进化的行业. 中国互联网行业在近期的十五年里.以如何的方式在"进化".我相信非常多奋斗在互联网战线上的你们最深有感触.读一读& ...
- UICollectionView基础用法
初始化部分: UICollectionViewFlowLayout *flowLayout= [[UICollectionViewFlowLayout alloc]init]; self.myColl ...
- CentOS 7.2 安装Gerrit 2.14.6
1.环境 本文使用VMWare虚拟机进行实验. 2核CPU,4GB内存,20GB硬盘,IP:192.168.159.131 CentOS 7.2最小安装(CentOS-7-x86_64-Minimal ...
- 织梦DEDE多选项筛选_联动筛选功能的实现_二次开发
织梦默认的列表页没有筛选功能,但有时候我们做产品列表页的时候,产品的字段比较多,很多人都需要用到筛选功能,这样可以让用户更方便的找到自己所需要的东西,实现这个联动筛选功能需要对织梦进行二次开发,下面就 ...
- android.annotation.SuppressLint
Lint是一个静态检查器,它围绕Android项目的正确性.安全性.性能.可用性以及可访问性进行分析.它检查的对象包括XML资源.位图.ProGuard配置文件.源文件甚至编译后的字节码. Lint包 ...
- Caffe-Windows下遇到过的问题、技巧、解决方案
转换数据,求均值: 转换数据 步骤大概是:建立一个train文件夹,里面放一个train.txt;建立一个test文件夹,里面放一个test.txt,然后分别运行以下两条bat命令: SET GLOG ...
- 「NOIP2012」「LuoguP1083」 借教室
Description 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借教室的 ...
- 【Codeforces 664A】 Complicated GCD
[题目链接] 点击打开链接 [算法] gcd(a,a+1) = 1 所以当a = b时,答案为a,否则为1 [代码] #include<bits/stdc++.h> using names ...
- 洛谷P3195 [HNOI2008]玩具装箱TOY——斜率优化DP
题目:https://www.luogu.org/problemnew/show/P3195 第一次用斜率优化...其实还是有点云里雾里的: 网上的题解都很详细,我的理解就是通过把式子变形,假定一个最 ...
- 文件的创建,读取,写入,修改,删除---python入门
转自:http://blog.163.com/jackylau_v/blog/static/175754040201181505158356/ 一.用Python创建一个新文件,内容是从0到9的整数, ...