多分支管理鸦采,線上線下分支管理控制項(xiàng)目,來回切換咕幻,常用的比較容易記住渔伯,不常用的很容易就模糊, 查找資料費(fèi)時(shí)費(fèi)力肄程,索性一次查完锣吼,記錄一下以待后用
命令行實(shí)踐
高手都是直接用命令行,用命令行顯得逼格更高蓝厌。
創(chuàng)建項(xiàng)目
首先我創(chuàng)建 Android 項(xiàng)目 GitBranchSample玄叠, Share Project on GitHub。
查看分支
查看本地所有分支:
$ git branch
* master
master 分支前的 * 字符拓提,它表示當(dāng)前所在的分支读恃。
查看遠(yuǎn)程所有分支:
$ git branch -r
? origin/master
列出所有本地分支和遠(yuǎn)程分支:
$ git branch -a
創(chuàng)建本地dev1 分支
$ git checkout -b dev1
Switched to a new branch 'dev1'
本地 master 分支默認(rèn)就是遠(yuǎn)程 master 分支,上面命令在此基礎(chǔ)上創(chuàng)建本地 dev1 分支代态,然后切換到 dev1 分支寺惫,相當(dāng)于以下兩條命令:
$ git branch dev1
$ git checkout dev1
想從遠(yuǎn)程分支 dev (遠(yuǎn)程有該分支)創(chuàng)建本地分支 dev1:
$ git checkout -b dev1 origin/dev
Switched to a new branch 'dev1'
開發(fā)提交
隨便修改 README.md 文件,然后提交:
add 文件
$ git add README.md
commit 信息
$ git commit -m "branch test"
[dev1 8643ecb] branch dev1
2 files changed, 3 insertions(+)
合并到本地 master 分支
分支 dev1 開發(fā)工作完成蹦疑,我們就可以切換回本地 master 分支:
$ git checkout master
Switched to branch 'master'
進(jìn)行本地分支 dev1 合并:
$ git merge dev1
Updating 82951ea..444bb8e
Fast-forward
README.md | 1 +
1 file changed, 1 insertion(+)
Fast-forward 信息西雀,“快進(jìn)模式”合并,這種模式下歉摧,刪除分支后艇肴,會(huì)丟掉分支信息乎澄,可以用 --no-ff 方式進(jìn)行 merge :
$ git merge --no-ff -m "merge with no-ff" dev1
如果分支很多瓢棒,這個(gè)分支歷史可能就會(huì)變得很復(fù)雜了,可以使用 rebase含蓉,提交的歷史會(huì)保持線性:
$ git rebase dev1
也是進(jìn)行本地分支 dev1 合并券盅。
刪除本地分支
$ git branch -d dev1
這是刪除帮哈,如果沒有完成合并會(huì)有提示,以下是強(qiáng)刪:
$ git branch -D dev1
Deleted branch dev1 (was d39f6c3).
創(chuàng)建遠(yuǎn)程分支 dev
直接提交
$ git push origin master:dev
這里冒號可以提交到指定分支锰镀,上面命令娘侍,把提交本地 master 分支到遠(yuǎn)程的 dev 分支咖刃,遠(yuǎn)程沒有dev這個(gè)分支,會(huì)創(chuàng)建憾筏。
git push origin master
這是本地 master 提交到遠(yuǎn)程主分支 master嚎杨,相當(dāng)于:
git push origin master:master
跟蹤遠(yuǎn)程分支
從遠(yuǎn)程分支 checkout 出來的本地分支,稱為 跟蹤分支 (tracking branch)氧腰。跟蹤分支是一種和某個(gè)遠(yuǎn)程分支有直接聯(lián)系的本地分支枫浙。在跟蹤分支里輸入 git pull/push,Git 會(huì)自行推斷應(yīng)該向哪個(gè)服務(wù)器的哪個(gè)分支更新/推送數(shù)據(jù)古拴。
手動(dòng)建立追蹤關(guān)系:
$ 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 分支追蹤遠(yuǎn)程 dev 分支箩帚。
查看所有分支跟蹤關(guān)系:
$ git branch -vv
* master 444bb8e [origin/dev] branch test
合并遠(yuǎn)程分支
我們把遠(yuǎn)程分支 dev 合并到 master,怎么做黄痪?
1、指定本地 master 分支追蹤遠(yuǎn)程 dev 分支
$ git branch -u origin/dev master
Branch master set up to track remote branch dev from origin.
2桅打、更新內(nèi)容
$ 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是嗜、開發(fā)提交遠(yuǎn)程分支 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(-)
進(jìn)行 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 分支追蹤遠(yuǎn)程 master 分支
$ git branch -u origin/master master
Branch master set up to track remote branch master from origin.
5鹅搪、更新內(nèi)容
$ git pull
Already up-to-date.
6、同樣提交遠(yuǎn)程分支 master
不用 commit 遭铺,上面已經(jīng) commit 了丽柿,也提交給 origin/master,這樣遠(yuǎn)程分支 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:以上遠(yuǎn)程分支合并航厚,我不知道是不是正確的方式,望指導(dǎo)锰蓬。
刪除遠(yuǎn)程分支
$ git push origin --delete dev
或者
$ git push origin :dev
遠(yuǎn)程分支 dev 將被刪除幔睬。
Android Studio 實(shí)踐
畢竟我們開發(fā)工具是 Android Studio,知道 Android Studio 進(jìn)行分支開發(fā)是必要的芹扭。
查看當(dāng)前分支
這個(gè)分支指的當(dāng)然是本地的麻顶,默認(rèn) master。
創(chuàng)建本地 dev1 分支
以 origin/master 為基礎(chǔ) checkout 本地分支 dev1舱卡。
合并到本地 master 分支
同樣修改 README.md 文件辅肾,add,commit轮锥,然后切換到 master 分支:
然后合并本地分支 dev1:
再 push 就 OK 了矫钓。
刪除本地分支
如上圖,有個(gè) Delete 按鈕,點(diǎn)擊直接干掉新娜。
創(chuàng)建遠(yuǎn)程分支 dev
直接提交赵辕,我們會(huì)發(fā)現(xiàn)是提交到遠(yuǎn)程 master 上,這里我們可以修改:
改成 dev概龄,點(diǎn)擊 Enter还惠,然后 Push,這樣遠(yuǎn)程就有了分支 dev私杜。
查看跟蹤遠(yuǎn)程分支
如上圖可以查看跟蹤關(guān)系蚕键,也可以手動(dòng)修改。
合并遠(yuǎn)程分支
修改 README.md 文件衰粹,add锣光,commit,分別提交到遠(yuǎn)程 dev 和 master 即可寄猩,是不是比命令行簡單多了啊嫉晶。
刪除遠(yuǎn)程分支
點(diǎn)擊 origin/dev,直接刪除就好了田篇。
拓展
git fetch
$ git fetch origin master
下載遠(yuǎn)程 master 的所有變動(dòng)到當(dāng)前分支,與 git pull 區(qū)別箍铭,沒有與本地合并泊柬。
查看當(dāng)前的遠(yuǎn)程庫
顯示對應(yīng)的克隆地址:
$ git remote -v
-v 為 --verbose 的簡寫,取首字母
修改遠(yuǎn)程倉庫地址
服務(wù)器要換地址了诈火,本地有 clone 出來的 git 厙兽赁,則需要修改一下 origin 的地址,以便能繼續(xù) push 和 pull冷守,項(xiàng)目所在目錄下執(zhí)行命令行:
git remote set-url origin 新地址
切換分支
我們新建一個(gè)分支(Branch1)后刀崖,這時(shí)如果我們要切換到master分支,我們點(diǎn)擊Local Branches下面的按鈕拍摇,然后在其左邊會(huì)彈出一個(gè)對話框亮钦,我們點(diǎn)擊Checkout就可以將其切換到master分支下了。要明白的是Local是存在本地Repo的充活,你可以直接進(jìn)行切換蜂莉。Remote是遠(yuǎn)程倉庫的,遠(yuǎn)程倉庫的你只能checkout到本地混卵,而不能切換過去映穗。 切換分支,addcommit下幕随,防止代碼丟失蚁滋。
git push origin dev:master
提交本地 dev 分支推送到遠(yuǎn)程master分支
git push origin dev:dev
提交本地 dev 分支作為遠(yuǎn)程的dev 分支
git push origin :dev
剛提交到遠(yuǎn)程的 dev 將被刪除,本地還是會(huì)保存的