新公司有些项目是用的 Git,之前公司都是 svn,为了练手 Git,我我的 APP 用到了,可是仅简单的 git pull/push 的使用,并未用到 Git 精髓,只有当项目中用到,才会紧迫去全面学习,因此说,在项目中进步是最快的。html
开发场景:远程有主分支 master,提供用户使用的正式的稳定的版本;开发分支 dev,用于平常开发。dev 们能够在本地任意建立本身的 Local Branch,而后合并到本地 master 再提交到远程分支 dev。android
高手都是直接用命令行,用命令行显得逼格更高。git
首先我建立 Android 项目 GitBranchSample, Share Project on GitHub。github
查看本地全部分支:android-studio
$ git branch * master
master 分支前的 * 字符,它表示当前所在的分支。bash
查看远程全部分支:服务器
$ git branch -r origin/master
列出全部本地分支和远程分支:svn
$ git branch -a
$ 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(+)
分支 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).
直接提交
$ 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,怎么作?
一、指定本地 master 分支追踪远程 dev 分支
$ git branch -u origin/dev master Branch master set up to track remote branch dev from origin.
二、更新内容
$ 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(-)
三、开发提交远程分支 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
四、指定本地 master 分支追踪远程 master 分支
$ git branch -u origin/master master Branch master set up to track remote branch master from origin.
五、更新内容
$ git pull Already up-to-date.
六、一样提交远程分支 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 进行分支开发是必要的。
这个分支指的固然是本地的,默认 master。
以 origin/master 为基础 checkout 本地分支 dev1。
一样修改 README.md 文件,add,commit,而后切换到 master 分支:
而后合并本地分支 dev1:
再 push 就 OK 了。
如上图,有个 Delete 按钮,点击直接干掉。
直接提交,咱们会发现是提交到远程 master 上,这里咱们能够修改:
改为 dev,点击 Enter,而后 Push,这样远程就有了分支 dev。
如上图能够查看跟踪关系,也能够手动修改。
修改 README.md 文件,add,commit,分别提交到远程 dev 和 master 便可,是否是比命令行简单多了啊。
点击 origin/dev,直接删除就行了。
$ 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 将被删除,本地仍是会保存的