詳解Android Studio Git分支實踐
新公司有些專案是用的 Git,以前公司都是 svn,為了練手 Git,我個人 APP 用到了,但是僅簡單的 git pull/push 的使用,並未用到 Git 精髓,只有當專案中用到,才會緊迫去全面學習,所以說,在專案中進步是最快的。
開發場景:遠端有主分支 master,提供使用者使用的正式的穩定的版本;開發分支 dev,用於日常開發。dev 們可以在本地任意建立自己的 Local Branch,然後合併到本地 master 再提交到遠端分支 dev。
命令列實踐
高手都是直接用命令列,用命令列顯得逼格更高。
建立專案
首先我建立 Android 專案 GitBranchSample, Share Project on GitHub。
檢視分支
檢視本地所有分支:
1 2 |
|
master 分支前的 * 字元,它表示當前所在的分支。
檢視遠端所有分支:
1 2 |
|
列出所有本地分支和遠端分支:
1 |
|
建立本地 dev1 分支
1 2 |
|
本地 master 分支預設就是遠端 master 分支,上面命令在此基礎上建立本地 dev1 分支,然後切換到 dev1 分支,相當於以下兩條命令:
1 2 |
|
想從遠端分支 dev (遠端有該分支)建立本地分支 dev1:
1 2 |
|
開發提交
隨便修改 README.md 檔案,然後提交:
add 檔案
1 |
|
commit 資訊
1 2 3 |
|
合併到本地 master 分支
分支 dev1 開發工作完成,我們就可以切換回本地 master 分支:
1 2 |
|
進行本地分支 dev1 合併:
1 2 3 4 5 |
|
Fast-forward 資訊,“快進模式”合併,這種模式下,刪除分支後,會丟掉分支資訊,可以用 --no-ff 方式進行 merge :
1 |
|
如果分支很多,這個分支歷史可能就會變得很複雜了,可以使用 rebase,提交的歷史會保持線性:
1 |
|
也是進行本地分支 dev1 合併。
刪除本地分支
1 |
|
這是刪除,如果沒有完成合並會有提示,以下是強刪:
1 2 |
|
建立遠端分支 dev
直接提交
1 |
|
這裡冒號可以提交到指定分支,上面命令,把提交本地 master 分支到遠端的 dev 分支,遠端沒有dev這個分支,會建立。
1 |
|
這是本地 master 提交到遠端主分支 master,相當於:
1 |
|
跟蹤遠端分支
從遠端分支 checkout 出來的本地分支,稱為 跟蹤分支 (tracking branch)。跟蹤分支是一種和某個遠端分支有直接聯絡的本地分支。在跟蹤分支裡輸入 git pull/push,Git 會自行推斷應該向哪個伺服器的哪個分支更新/推送資料。
手動建立追蹤關係:
1 2 |
|
或者:
1 2 |
|
指定本地 master 分支追蹤遠端 dev 分支。
檢視所有分支跟蹤關係:
1 2 |
|
合併遠端分支
我們把遠端分支 dev 合併到 master,怎麼做?
1、指定本地 master 分支追蹤遠端 dev 分支
1 2 |
|
2、更新內容
1 2 3 4 5 6 7 8 9 10 11 |
|
3、開發提交遠端分支 dev
修改了 README.md 檔案,然後提交:
add 檔案
1 |
|
commit 資訊
1 2 3 |
|
進行 push
1 2 3 4 5 6 7 8 9 |
|
4、指定本地 master 分支追蹤遠端 master 分支
1 2 |
|
5、更新內容
1 2 |
|
6、同樣提交遠端分支 master
不用 commit ,上面已經 commit 了,也提交給 origin/master,這樣遠端分支 dev 和 master 就是一樣的。
1 2 3 4 |
|
PS:以上遠端分支合併,我不知道是不是正確的方式,望指導。
刪除遠端分支
1 |
|
或者
1 |
|
遠端分支 dev 將被刪除。
Android Studio 實踐
畢竟我們開發工具是 Android Studio,知道 Android Studio 進行分支開發是必要的。
檢視當前分支
這個分支指的當然是本地的,預設 master。
建立本地 dev1 分支
以 origin/master 為基礎 checkout 本地分支 dev1。
合併到本地 master 分支
同樣修改 README.md 檔案,add,commit,然後切換到 master 分支:
然後合併本地分支 dev1:
再 push 就 OK 了。
刪除本地分支
如上圖,有個 Delete 按鈕,點選直接幹掉。
建立遠端分支 dev
直接提交,我們會發現是提交到遠端 master 上,這裡我們可以修改:
改成 dev,點選 Enter,然後 Push,這樣遠端就有了分支 dev。
檢視跟蹤遠端分支
如上圖可以檢視跟蹤關係,也可以手動修改。
合併遠端分支
修改 README.md 檔案,add,commit,分別提交到遠端 dev 和 master 即可,是不是比命令列簡單多了啊。
刪除遠端分支
點選 origin/dev,直接刪除就好了。
拓展
git fetch
1 |
|
下載遠端 master 的所有變動到當前分支,與 git pull 區別,沒有與本地合併。
檢視當前的遠端庫
顯示對應的克隆地址:
1 |
|
-v 為 --verbose 的簡寫,取首字母
修改遠端倉庫地址
伺服器要換地址了,本地有 clone 出來的 git 厙,則需要修改一下 origin 的地址,以便能繼續 push 和 pull,專案所在目錄下執行命令列:
1 |
|
切換分支
我們新建一個分支(Branch1)後,這時如果我們要切換到master分支,我們點選Local Branches下面的按鈕,然後在其左邊會彈出一個對話方塊,我們點選Checkout就可以將其切換到master分支下了。要明白的是Local是存在本地Repo的,你可以直接進行切換。Remote是遠端倉庫的,遠端倉庫的你只能checkout到本地,而不能切換過去。 切換分支,addcommit下,防止程式碼丟失。
1 |
|
提交本地 dev 分支推送到遠端master分支
1 |
|
提交本地 dev 分支作為遠端的dev 分支
1 |
|
剛提交到遠端的 dev 將被刪除,本地還是會儲存的
參考