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