Android Studio Git 分支实践

新公司有些项目是用的 Git,以前公司都是 svn,为了练手 Git,我个人 APP 用到了,但是仅简单的 git pull/push 的使用,并未用到 Git 精髓,只有当项目中用到,才会紧迫去全面学习,所以说,在项目中进步是最快的。

开发场景:远程有主分支 master,提供用户使用的正式的稳定的版本;开发分支 dev,用于日常开发。dev 们可以在本地任意创建自己的 Local Branch,然后合并到本地 master 再提交到远程分支 dev。

命令行实践

高手都是直接用命令行,用命令行显得逼格更高。

创建项目

首先我创建 Android 项目 GitBranchSample, Share Project on GitHub。

查看分支

查看本地所有分支:

$ git branch
* master

master 分支前的 * 字符,它表示当前所在的分支。

查看远程所有分支:

$ git branch -r
  origin/master

列出所有本地分支和远程分支:

$ git branch -a

创建本地 dev1 分支

$ git checkout -b dev1 
Switched to a new branch 'dev1'

本地 master 分支默认就是远程 master 分支,上面命令在此基础上创建本地 dev1 分支,然后切换到 dev1 分支,相当于以下两条命令:

$ git branch dev1
$ git checkout dev1

想从远程分支 dev (远程有该分支)创建本地分支 dev1:

$ git checkout -b dev1 origin/dev
Switched to a new branch 'dev1'

开发提交

随便修改 README.md 文件,然后提交:

add 文件

$ git add README.md

commit 信息

$ git commit -m "branch test"
[dev1 8643ecb] branch dev1
2 files changed, 3 insertions(+)

合并到本地 master 分支

分支 dev1 开发工作完成,我们就可以切换回本地 master 分支:

$ git checkout master
Switched to branch 'master'

进行本地分支 dev1 合并:

$ git merge dev1
Updating 82951ea..444bb8e
Fast-forward
 README.md | 1 +
 1 file changed, 1 insertion(+)

Fast-forward 信息,“快进模式”合并,这种模式下,删除分支后,会丢掉分支信息,可以用 --no-ff 方式进行 merge :

$ git merge --no-ff -m "merge with no-ff" dev1

如果分支很多,这个分支历史可能就会变得很复杂了,可以使用 rebase,提交的历史会保持线性:

$ git rebase dev1

也是进行本地分支 dev1 合并。

删除本地分支

$ git branch -d dev1

这是删除,如果没有完成合并会有提示,以下是强删:

$ git branch -D dev1
Deleted branch dev1 (was d39f6c3).

创建远程分支 dev

直接提交

$ git push origin master:dev

这里冒号可以提交到指定分支,上面命令,把提交本地 master 分支到远程的 dev 分支,远程没有dev这个分支,会创建。

git push origin master 

这是本地 master 提交到远程主分支 master,相当于:

git push origin master:master

跟踪远程分支

从远程分支 checkout 出来的本地分支,称为 跟踪分支 (tracking branch)。跟踪分支是一种和某个远程分支有直接联系的本地分支。在跟踪分支里输入 git pull/push,Git 会自行推断应该向哪个服务器的哪个分支更新/推送数据。

手动建立追踪关系:

$ git branch -u origin/dev master
Branch master set up to track remote branch dev from origin.

或者:

$ git branch --set-upstream-to origin/dev master
Branch master set up to track remote branch dev from origin.

指定本地 master 分支追踪远程 dev 分支。

查看所有分支跟踪关系:

$ git branch -vv
* master 444bb8e [origin/dev] branch test

合并远程分支

我们把远程分支 dev 合并到 master,怎么做?

1、指定本地 master 分支追踪远程 dev 分支

$ git branch -u origin/dev master
Branch master set up to track remote branch dev from origin.

2、更新内容

$ git pull
remote: Counting objects: 3, done.
remote: Compressing objects: 100% (3/3), done.
remote: Total 3 (delta 1), reused 0 (delta 0), pack-reused 0
Unpacking objects: 100% (3/3), done.
From https://github.com/WuXiaolong/GitBranchSample
   0138684..d0ca159  dev        -> origin/dev
Updating 0138684..d0ca159
Fast-forward
 README.md | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

3、开发提交远程分支 dev

修改了 README.md 文件,然后提交:

add 文件

$ git add README.md

commit 信息

$ git commit -m "merge origin/dev"
[master 44150b4] merge origin/dev
 1 file changed, 1 insertion(+), 1 deletion(-)

进行 push

$ git push origin master:dev
Counting objects: 3, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 310 bytes | 0 bytes/s, done.
Total 3 (delta 1), reused 0 (delta 0)
remote: Resolving deltas: 100% (1/1), completed with 1 local object.
To https://github.com/WuXiaolong/GitBranchSample.git
   d0ca159..44150b4  master -> dev

4、指定本地 master 分支追踪远程 master 分支

$ git branch -u origin/master master
Branch master set up to track remote branch master from origin.

5、更新内容

$ git pull
Already up-to-date.

6、同样提交远程分支 master

不用 commit ,上面已经 commit 了,也提交给 origin/master,这样远程分支 dev 和 master 就是一样的。

$ git push origin master
Total 0 (delta 0), reused 0 (delta 0)
To https://github.com/WuXiaolong/GitBranchSample.git
   0138684..44150b4  master -> master

PS:以上远程分支合并,我不知道是不是正确的方式,望指导。

删除远程分支

$ git push origin --delete dev

或者

$ git push origin :dev

远程分支 dev 将被删除。

Android Studio 实践

毕竟我们开发工具是 Android Studio,知道 Android Studio 进行分支开发是必要的。

查看当前分支

image

这个分支指的当然是本地的,默认 master。

创建本地 dev1 分支

image
image

以 origin/master 为基础 checkout 本地分支 dev1。

合并到本地 master 分支

同样修改 README.md 文件,add,commit,然后切换到 master 分支:


image

然后合并本地分支 dev1:


image

再 push 就 OK 了。

删除本地分支

如上图,有个 Delete 按钮,点击直接干掉。

创建远程分支 dev

直接提交,我们会发现是提交到远程 master 上,这里我们可以修改:


image

改成 dev,点击 Enter,然后 Push,这样远程就有了分支 dev。

查看跟踪远程分支

如上图可以查看跟踪关系,也可以手动修改。

合并远程分支

修改 README.md 文件,add,commit,分别提交到远程 dev 和 master 即可,是不是比命令行简单多了啊。

删除远程分支

点击 origin/dev,直接删除就好了。

拓展

git fetch

$ git fetch origin master

下载远程 master 的所有变动到当前分支,与 git pull 区别,没有与本地合并。

查看当前的远程库

显示对应的克隆地址:

$ git remote -v

-v 为 --verbose 的简写,取首字母

修改远程仓库地址

服务器要换地址了,本地有 clone 出来的 git 厍,则需要修改一下 origin 的地址,以便能继续 push 和 pull,项目所在目录下执行命令行:

git remote set-url origin 新地址

切换分支

我们新建一个分支(Branch1)后,这时如果我们要切换到master分支,我们点击Local Branches下面的按钮,然后在其左边会弹出一个对话框,我们点击Checkout就可以将其切换到master分支下了。要明白的是Local是存在本地Repo的,你可以直接进行切换。Remote是远程仓库的,远程仓库的你只能checkout到本地,而不能切换过去。 切换分支,addcommit下,防止代码丢失。

git push origin dev:master
提交本地 dev 分支推送到远程master分支

git push origin dev:dev
提交本地 dev 分支作为远程的dev 分支

git push origin :dev
刚提交到远程的 dev 将被删除,本地还是会保存的

参考

常用 Git 命令清单

Git分支管理策略

image
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容