git中push和pull的區別:1、“git push”命令是將本地庫中的最新信息發送給遠端庫,用於將本地分支的更新,推送到遠端主機;2、“ git pull」指令是從遠端取得最新版本到本機庫,用於從另一個儲存庫或本機分支取得並整合整合。
本文操作環境:Windows10系統、Git2.30.0版、Dell G3電腦。
git中push和pull的差別是什麼
#git push與git pull是一對推送/拉取分支的git指令。
git push 使用本地的對應分支來更新對應的遠端分支
$ git push <远程主机名> <本地分支名>:<远程分支名>
注意: 命令中的本地分支是指將要被推送到遠端的分支,而遠端分支是指推送的目標分支,即將本地分支合併到遠端分支。
如果省略遠端分支名,則表示將本地分支推送與之存在」追蹤關係」的遠端分支(通常兩者同名),如果該遠端分支不存在,則會被新建。
$ git push origin master
上面指令表示,將本地的master分支推送到origin主機的master分支。如果後者不存在,則會被新建。
origin是一個遠端廠庫位址。
如果省略本機分支名,則表示刪除指定的遠端分支,因為這等同於推送空的本機分支到遠端分支,這條指令是刪除遠端master分支。
$ git push origin :master # 等同于 $ git push origin --delete master
上面指令表示刪除origin主機的master分支。
如果目前分支與遠端分支之間存在追蹤關係(即分支名稱相同),則本機分支和遠端分支都可以省略。
$ git push origin
上面指令表示,將目前分支推送到origin主機的對應分支。
如果目前分支只有一個追蹤分支,那麼主機名稱都可以省略。
$ git push
如果目前分支與多個主機存在追蹤關係,則可以使用-u選項指定一個預設主機,這樣後面就可以不加任何參數使用git push。
$ git push -u origin master
上面指令將本地的master分支推送到origin主機,同時指定origin為預設主機,後面就可以不加任何參數使用git push了。
不帶任何參數的git push,預設只推送目前分支,這叫做simple方式。此外,還有一種matching方式,會推送所有有對應的遠端分支的本機分支。 Git 2.0版本之前,預設採用matching方法,現在改為預設採用simple方式。如果要修改這個設置,可以採用git config指令。
$ git config --global push.default matching # 或者 $ git config --global push.default simple
還有一種情況,就是不管是否存在對應的遠端分支,將本地的所有分支都推送到遠端主機,這時需要使用–all選項。
$ git push --all origin
上面指令表示,將所有本機分支都推送到origin主機。
如果遠端主機的版本比本機版本更新,推送時Git會報錯,要求先在本地做git pull合併差異,然後再推送到遠端主機。這時,如果你一定要推送,可以使用–force選項。
$ git push --force origin
上面指令使用–force選項,結果導致在遠端主機產生一個」非直排式」的合併(non-fast-forward merge)。除非你很確定要這樣做,否則應該盡量避免使用–force選項。
最後,git push不會推送標籤(tag),除非使用–tags選項。
$ git push origin --tags
git pull 取得並合併其他的廠庫,或本地的其他分支。
git pull 與 git push操作的目的相同,但是操作的目標相反。指令格式如下:
git pull <远程主机> <远程分支>:<本地分支>
例如:
git pull origin master:my_test
上面的指令是將origin廠庫的master分支拉取並合併到本機的my_test分支上。
如果省略本機分支,則會自動合併到目前所在分支上。如下:
git pull origin master
註:如果你想參與github上的一些優秀的項目,則下面提供一個通用的例子:
首先,需要一個github的帳號,並fork一個你感興趣的repository。
下面描述過程中會涉及兩個遠程主分支,為了很好的區別,我們把fork出來的主分支稱為遠程A repository,本fork的分支稱為遠程B repository
$git clone <远程Arepository> #克隆你fork出来的分支 $git remote add <远程Brepository标签> git@github.com:XXXX/ceph.git #添加远程Brepository标签 $git pull <远程B厂库标签> master:master #从远程Brepository的master分支拉取最新objects合并到本地master分支 $git checkout YYYY #切换到要修改的分支上 $git branch develop; git checkout develop #在当前分支的基础上创建一个开发分支,并切换到该分支上,你将在该分支上coding coding...... #在工作区coding $git add .#将修改保存到索引区 $git commit -a #将修改提交到本地分区 $git push origin my_test:my_test #将本地分支my_test提交到远程A repository的my_test分支上
接著在github web介面上將my_test分支合併到你需改的遠端B repository 分支上。等待管理員review,如果有問題,就繼續在develop分支當修改,並commit –amend,在之前的commit上修改。知道被meger。
推薦學習:《Git教學》
以上是git中push和pull的差別是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!