git 命令

多分支管理鸦采,線上線下分支管理控制項(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ì)保存的

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市辕录,隨后出現(xiàn)的幾起案子澄阳,更是在濱河造成了極大的恐慌,老刑警劉巖踏拜,帶你破解...
    沈念sama閱讀 219,539評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件碎赢,死亡現(xiàn)場離奇詭異,居然都是意外死亡速梗,警方通過查閱死者的電腦和手機(jī)肮塞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評論 3 396
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來姻锁,“玉大人枕赵,你說我怎么就攤上這事∥涣ィ” “怎么了拷窜?”我有些...
    開封第一講書人閱讀 165,871評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長涧黄。 經(jīng)常有香客問我篮昧,道長,這世上最難降的妖魔是什么笋妥? 我笑而不...
    開封第一講書人閱讀 58,963評論 1 295
  • 正文 為了忘掉前任懊昨,我火速辦了婚禮,結(jié)果婚禮上春宣,老公的妹妹穿的比我還像新娘酵颁。我一直安慰自己,他們只是感情好月帝,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評論 6 393
  • 文/花漫 我一把揭開白布躏惋。 她就那樣靜靜地躺著,像睡著了一般嚷辅。 火紅的嫁衣襯著肌膚如雪簿姨。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,763評論 1 307
  • 那天潦蝇,我揣著相機(jī)與錄音款熬,去河邊找鬼。 笑死攘乒,一個(gè)胖子當(dāng)著我的面吹牛贤牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播则酝,決...
    沈念sama閱讀 40,468評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼殉簸,長吁一口氣:“原來是場噩夢啊……” “哼闰集!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起般卑,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤武鲁,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后蝠检,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體沐鼠,經(jīng)...
    沈念sama閱讀 45,850評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評論 3 338
  • 正文 我和宋清朗相戀三年叹谁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了饲梭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,144評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡焰檩,死狀恐怖憔涉,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情析苫,我是刑警寧澤兜叨,帶...
    沈念sama閱讀 35,823評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站衩侥,受9級特大地震影響国旷,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜顿乒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評論 3 331
  • 文/蒙蒙 一议街、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧璧榄,春花似錦、人聲如沸吧雹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽雄卷。三九已至搓蚪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間丁鹉,已是汗流浹背妒潭。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留揣钦,地道東北人雳灾。 一個(gè)月前我還...
    沈念sama閱讀 48,415評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像冯凹,于是被迫代替她去往敵國和親谎亩。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評論 2 355