Git初学札记(六)————在远程新建本地Branch与在本地新建远程Branch
引言
本篇博客介紹將現(xiàn)有的本地分支以新的分支形式推送到遠(yuǎn)程庫(kù)中,和以新的分支的形式從遠(yuǎn)程庫(kù)中拉取一個(gè)分支。這兩個(gè)功能都是比較簡(jiǎn)單的操作,但是在實(shí)際開發(fā)中,可能會(huì)在開發(fā)初期有所觸及。比如我們希望將遠(yuǎn)程的dev分支拉取到本地來進(jìn)行開發(fā),或者將本地的dev分支推到遠(yuǎn)程庫(kù)中去等等。
推送本地分支
在EGit中,我們切換到一個(gè)已存在的分支,或者新建一個(gè)新的分支:
右鍵項(xiàng)目 ,Team>Switch To>New Branch
此時(shí),我們已經(jīng)切換到了新建的這個(gè)"feature_push_new_branch"分支上
再次右鍵項(xiàng)目>Team>Push Branch '當(dāng)前分支名稱'...
這里由于項(xiàng)目已經(jīng)關(guān)聯(lián)了一個(gè)遠(yuǎn)程庫(kù),因此Destination選項(xiàng)欄中的信息已經(jīng)自動(dòng)創(chuàng)建完畢,而Branch輸入框就代表在遠(yuǎn)程庫(kù)上顯示的分支名稱,這里為了區(qū)分顯示,我特意手動(dòng)修改了一下遠(yuǎn)程庫(kù)中分支的名稱(加了一個(gè)“GitHub”),點(diǎn)擊Preview。
在push確認(rèn)信息提示框內(nèi),我們可以確認(rèn)我們的push分支信息,可以看到[new branch]的標(biāo)識(shí),代表是新的分支。點(diǎn)擊Push。等待片刻后,就會(huì)收到一個(gè)提示信息。
最后,檢查一下遠(yuǎn)程庫(kù)中的分支是否多了一個(gè)名為“feature_push_new_branch_GitHub”新分支。
完美!????乛?乛????
拉取遠(yuǎn)程分支
有推送就有拉取。我們假設(shè)已經(jīng)在遠(yuǎn)程庫(kù)存在了dev分支(在上圖中我們也可以看到),這個(gè)時(shí)候我們檢查一下本地是否有dev分支:
刪除本地分支
在Git Repositories視圖中我們可以看到本地全部的倉(cāng)庫(kù)信息,找到對(duì)應(yīng)的倉(cāng)庫(kù),Branches>Local
如圖可以很清晰的看到,我們的當(dāng)前分支時(shí)feature_push_new_branch上,且已經(jīng)存在了dev分支(實(shí)際上我就是用dev分支練習(xí)了將分支push到遠(yuǎn)程新分支的功能),接下來,我們先刪除這個(gè)dev分支,然后我們?cè)賴L試從GitHub上取下dev分支。
右鍵需要?jiǎng)h除的分支>Delete Branch ,注意當(dāng)前分支是無法刪除的,如果想刪除當(dāng)前分支,請(qǐng)先切換到其他分支上去。
刪除結(jié)果如下:
可以看到dev分支已經(jīng)被刪除了。另外需要說明一下,如果被刪除的分支有一些還沒有來得及合并的修改,那么在刪除的時(shí)候會(huì)彈出提示信息,讓你再一次確認(rèn)要?jiǎng)h除的分支。
修改checked-out遠(yuǎn)程分支?!
還是在Git Repositories視圖中,我們看到Remote Tracking中有一個(gè)名叫origin的遠(yuǎn)程庫(kù)(不用懷疑,就是GitHub上對(duì)應(yīng)的項(xiàng)目),它的下面有一個(gè)dev分支(如果沒有,請(qǐng)嘗試F5刷新一下Remote Tracking文件夾)
這里顯示的dev分支的縮略信息未必是實(shí)時(shí)的,我嘗試在遠(yuǎn)程dev分支上添加了一個(gè)readme文件,但是在此處刷新是無法顯示這個(gè)最新操作的,但是通過checkout(分支上右鍵>Check Out)依然可以拿到最新的提交信息。如下圖checkout的結(jié)果:
請(qǐng)注意,可以看到我們的當(dāng)前分支已經(jīng)從之前的feature_push_new_branch切換到了遠(yuǎn)程庫(kù)的dev分支上。
但是如果此刻你直接修改checkout出的代碼,是無法被本地Git倉(cāng)庫(kù)追蹤到的,因?yàn)楸镜夭]有對(duì)應(yīng)的分支來追蹤這些修改,而且遠(yuǎn)程庫(kù)也不會(huì)記錄你此刻的任何修改,即此刻的操作是無用的。
這點(diǎn)千萬要注意,建議小伙伴嘗試一下直接修改checkout出的遠(yuǎn)程分支,看看如果切換回了master分支上,還能不能再重新找回剛才在checkout出的遠(yuǎn)程分支dev上的任何修改,或者看看遠(yuǎn)程庫(kù)上有沒有任何變化被記錄。
因此,如果希望修改遠(yuǎn)程的分支,必須修改本地分支然后再push,不可以直接修改checkout出的遠(yuǎn)程分支。
但是如果你忘記了這點(diǎn),依然在checkout出的遠(yuǎn)程分支上做了一些修改并且已經(jīng)commit了,你切換到了master分支上準(zhǔn)備合并這些修改,突然,你發(fā)現(xiàn)找不到了這些修改怎么辦?不知道小伙伴們是否還記得 git reflog指令?沒錯(cuò),reflog會(huì)記錄下你的每次提交,所以,你可以去查看一下Git Reflog歷史記錄:
必須在Git Repositories視圖,右鍵項(xiàng)目 > Show In > Git Reflog
找到你剛剛做的修改的commit,右鍵 > Checkout ,即檢出了剛才的馬虎修改:
拉取遠(yuǎn)程分支
那么如何將遠(yuǎn)程的分支拉取到本地的一個(gè)新的分支上呢?
右鍵遠(yuǎn)程分支 > Create Branch...
完成新建分支向?qū)?#xff1a;
點(diǎn)擊Finish 結(jié)果如下:
可以看到,我們已經(jīng)將遠(yuǎn)程的dev分支下載(拉取)到了本地,且已經(jīng)checkout,目前的工作區(qū)就是這個(gè)剛剛新建的與遠(yuǎn)程dev分支相關(guān)聯(lián)的分支了,可以放心大膽的在這個(gè)分支上修改提交,Git倉(cāng)庫(kù)會(huì)一如既往地幫助我們跟蹤它的變化。
總結(jié)
本章介紹了如何將新分支push到遠(yuǎn)程庫(kù),以及拉取遠(yuǎn)程的分支(或者可以稱為在本地建立一個(gè)與遠(yuǎn)程某個(gè)分支相關(guān)聯(lián)的新分支)。
另外還包括了一些其他的小操作,如:刪除本地分支,修改了剛剛checkout的遠(yuǎn)程分支的解決辦法。
其實(shí)對(duì)于普通開發(fā)者而言,拉取遠(yuǎn)程分支的操作可能會(huì)用得多一些,推送新分支到遠(yuǎn)程這個(gè)操作可能會(huì)影響服務(wù)器Git管理的混亂,因此一般都是由項(xiàng)目組長(zhǎng)將新的分支push到遠(yuǎn)程去。
文章描述的過程盡可能詳盡,配圖盡可能詳盡,并不是言簡(jiǎn)意賅的類型。
喜歡的朋友可以點(diǎn)贊分享,如有疑問,歡迎文末留言。
參考與感謝
《EGit/User Guide》
總結(jié)
以上是生活随笔為你收集整理的Git初学札记(六)————在远程新建本地Branch与在本地新建远程Branch的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: client中周期性边界_(整理)周期性
- 下一篇: JVM 运行时数据区域总结