真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

git中push和pull的區(qū)別有哪些

這篇“git中push和pull的區(qū)別有哪些”文章的知識點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“git中push和pull的區(qū)別有哪些”文章吧。

你所需要的網(wǎng)站建設(shè)服務(wù),我們均能行業(yè)靠前的水平為你提供.標(biāo)準(zhǔn)是產(chǎn)品質(zhì)量的保證,主要從事成都網(wǎng)站設(shè)計、成都做網(wǎng)站、企業(yè)網(wǎng)站建設(shè)、移動網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計、品牌網(wǎng)站設(shè)計、網(wǎng)頁制作、做網(wǎng)站、建網(wǎng)站。成都創(chuàng)新互聯(lián)公司擁有實力堅強(qiáng)的技術(shù)研發(fā)團(tuán)隊及素養(yǎng)的視覺設(shè)計專才。

git中push和pull的區(qū)別:1、“git push”命令是將本地庫中的最新信息發(fā)送給遠(yuǎn)程庫,用于將本地分支的更新,推送到遠(yuǎn)程主機(jī);2、“git pull”命令是從遠(yuǎn)程獲取最新版本到本地庫,用于從另一個存儲庫或本地分支獲取并集成整合。

本文操作環(huán)境:Windows10系統(tǒng)、Git2.30.0版、Dell G3電腦。

git中push和pull的區(qū)別是什么

git push與git pull是一對推送/拉取分支的git命令。

git push 使用本地的對應(yīng)分支來更新對應(yīng)的遠(yuǎn)程分支

$ git push <遠(yuǎn)程主機(jī)名> <本地分支名>:<遠(yuǎn)程分支名>

注意: 命令中的本地分支是指將要被推送到遠(yuǎn)端的分支,而遠(yuǎn)程分支是指推送的目標(biāo)分支,即將本地分支合并到遠(yuǎn)程分支。

如果省略遠(yuǎn)程分支名,則表示將本地分支推送與之存在”追蹤關(guān)系”的遠(yuǎn)程分支(通常兩者同名),如果該遠(yuǎn)程分支不存在,則會被新建。

$ git push origin master

上面命令表示,將本地的master分支推送到origin主機(jī)的master分支。如果后者不存在,則會被新建。

origin是一個遠(yuǎn)程廠庫地址。

如果省略本地分支名,則表示刪除指定的遠(yuǎn)程分支,因為這等同于推送一個空的本地分支到遠(yuǎn)程分支,這條命令是刪除遠(yuǎn)程master分支。

$ git push origin :master
# 等同于
$ git push origin --delete master

上面命令表示刪除origin主機(jī)的master分支。

如果當(dāng)前分支與遠(yuǎn)程分支之間存在追蹤關(guān)系(即分支名相同),則本地分支和遠(yuǎn)程分支都可以省略。

$ git push origin

上面命令表示,將當(dāng)前分支推送到origin主機(jī)的對應(yīng)分支。

如果當(dāng)前分支只有一個追蹤分支,那么主機(jī)名都可以省略。

$ git push

如果當(dāng)前分支與多個主機(jī)存在追蹤關(guān)系,則可以使用-u選項指定一個默認(rèn)主機(jī),這樣后面就可以不加任何參數(shù)使用git push。

$ git push -u origin master

上面命令將本地的master分支推送到origin主機(jī),同時指定origin為默認(rèn)主機(jī),后面就可以不加任何參數(shù)使用git push了。

不帶任何參數(shù)的git push,默認(rèn)只推送當(dāng)前分支,這叫做simple方式。此外,還有一種matching方式,會推送所有有對應(yīng)的遠(yuǎn)程分支的本地分支。Git 2.0版本之前,默認(rèn)采用matching方法,現(xiàn)在改為默認(rèn)采用simple方式。如果要修改這個設(shè)置,可以采用git config命令。

$ git config --global push.default matching
# 或者
$ git config --global push.default simple

還有一種情況,就是不管是否存在對應(yīng)的遠(yuǎn)程分支,將本地的所有分支都推送到遠(yuǎn)程主機(jī),這時需要使用–all選項。

$ git push --all origin

上面命令表示,將所有本地分支都推送到origin主機(jī)。

如果遠(yuǎn)程主機(jī)的版本比本地版本更新,推送時Git會報錯,要求先在本地做git pull合并差異,然后再推送到遠(yuǎn)程主機(jī)。這時,如果你一定要推送,可以使用–force選項。

$ git push --force origin

上面命令使用–force選項,結(jié)果導(dǎo)致在遠(yuǎn)程主機(jī)產(chǎn)生一個”非直進(jìn)式”的合并(non-fast-forward merge)。除非你很確定要這樣做,否則應(yīng)該盡量避免使用–force選項。

最后,git push不會推送標(biāo)簽(tag),除非使用–tags選項。

$ git push origin --tags

git pull 獲取并合并其他的廠庫,或者本地的其他分支。

git pull 與 git push操作的目的相同,但是操作的目標(biāo)相反。命令格式如下:

git pull <遠(yuǎn)程主機(jī)> <遠(yuǎn)程分支>:<本地分支>

例如:

git pull origin master:my_test

上面的命令是將origin廠庫的master分支拉取并合并到本地的my_test分支上。

如果省略本地分支,則將自動合并到當(dāng)前所在分支上。如下:

git pull origin master

注:如果你想?yún)⑴cgithub上的一些優(yōu)秀的項目,則下面提供一個通用的例子:

首先,需要一個github的賬號,并fork一個你感興趣的repository。

下面描述過程中會涉及兩個遠(yuǎn)程主分支,為了很好的區(qū)別,我們把fork出來的主分支稱為遠(yuǎn)程A repository,本fork的分支稱為遠(yuǎn)程B repository

$git clone <遠(yuǎn)程Arepository> #克隆你fork出來的分支
$git remote add <遠(yuǎn)程Brepository標(biāo)簽> git@github.com:XXXX/ceph.git #添加遠(yuǎn)程Brepository標(biāo)簽
$git pull <遠(yuǎn)程B廠庫標(biāo)簽> master:master  #從遠(yuǎn)程Brepository的master分支拉取最新objects合并到本地master分支
$git checkout YYYY #切換到要修改的分支上
$git branch develop; git checkout develop #在當(dāng)前分支的基礎(chǔ)上創(chuàng)建一個開發(fā)分支,并切換到該分支上,你將在該分支上coding
coding...... #在工作區(qū)coding
$git add .#將修改保存到索引區(qū)
$git commit -a #將修改提交到本地分區(qū)
$git push origin my_test:my_test #將本地分支my_test提交到遠(yuǎn)程A repository的my_test分支上

然后在github web界面上將my_test分支合并到你需改的遠(yuǎn)程B repository 分支上。等待管理員review,如果有問題,就繼續(xù)在develop分支當(dāng)修改,并commit –amend,在之前的commit上修改。知道被meger。

以上就是關(guān)于“git中push和pull的區(qū)別有哪些”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


文章名稱:git中push和pull的區(qū)別有哪些
網(wǎng)站鏈接:http://weahome.cn/article/jdscci.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部