Git學(xué)習(xí)總結(jié)

GIT教程

關(guān)聯(lián)遠(yuǎn)程庫:

要關(guān)聯(lián)一個(gè)遠(yuǎn)程庫,使用命令git remote add origin git@server-name:path/repo-name.git;

關(guān)聯(lián)后,使用命令git push -u origin master第一次推送master分支的所有內(nèi)容;

此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;

分布式版本系統(tǒng)的最大好處之一是在本地工作完全不需要考慮遠(yuǎn)程庫的存在,也就是有沒有聯(lián)網(wǎng)都可以正常工作,而SVN在沒有聯(lián)網(wǎng)的時(shí)候是拒絕干活的!當(dāng)有網(wǎng)絡(luò)的時(shí)候,再把本地提交推送一下就完成了同步,真是太方便了!

克隆倉庫:

要克隆一個(gè)倉庫,首先必須知道倉庫的地址,然后使用git clone命令克隆。

Git支持多種協(xié)議,包括https,但通過ssh支持的原生git協(xié)議速度最快。

分支:

分支在實(shí)際中有什么用呢?假設(shè)你準(zhǔn)備開發(fā)一個(gè)新功能,但是需要兩周才能完成,第一周你寫了50%的代碼,如果立刻提交,由于代碼還沒寫完,不完整的代碼庫會導(dǎo)致別人不能干活了。如果等代碼全部寫完再一次提交,又存在丟失每天進(jìn)度的巨大風(fēng)險(xiǎn)。

現(xiàn)在有了分支,就不用怕了。你創(chuàng)建了一個(gè)屬于你自己的分支,別人看不到,還繼續(xù)在原來的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到開發(fā)完畢后,再一次性合并到原來的分支上,這樣,既安全,又不影響別人工作。

[if !vml]

[endif]

Git鼓勵(lì)大量使用分支:

查看分支:git branch

創(chuàng)建分支:git branch

切換分支:git checkout <name>或者git switch

創(chuàng)建+切換分支:git checkout -b <name>或者git switch -c

合并某分支到當(dāng)前分支:git merge

刪除分支:git branch -d

沖突:

當(dāng)Git無法自動合并分支時(shí),就必須首先解決沖突。解決沖突后,再提交,合并完成。

解決沖突就是把Git合并失敗的文件手動編輯為我們希望的內(nèi)容,再提交。

用git

log --graph命令可以看到分支合并圖。

bug修復(fù):

修復(fù)bug時(shí),我們會通過創(chuàng)建新的bug分支進(jìn)行修復(fù),然后合并,最后刪除;

當(dāng)手頭工作沒有完成時(shí),先把工作現(xiàn)場git stash一下,然后去修復(fù)bug,修復(fù)后,再git stash pop,回到工作現(xiàn)場;

在master分支上修復(fù)的bug,想要合并到當(dāng)前dev分支,可以用git

cherry-pick <commit>命令,把bug提交的修改“復(fù)制”到當(dāng)前分支,避免重復(fù)勞動。

feature分支:

開發(fā)一個(gè)新feature,最好新建一個(gè)分支;

如果要丟棄一個(gè)沒有被合并過的分支,可以通過git branch -D <name>強(qiáng)行刪除。

多人協(xié)作:

1.并不是一定要把本地分支往遠(yuǎn)程推送,那么,哪些分支需要推送,哪些不需要呢?

master分支是主分支,因此要時(shí)刻與遠(yuǎn)程同步;

dev分支是開發(fā)分支,團(tuán)隊(duì)所有成員都需要在上面工作,所以也需要與遠(yuǎn)程同步;

bug分支只用于在本地修復(fù)bug,就沒必要推到遠(yuǎn)程了,除非老板要看看你每周到底修復(fù)了幾個(gè)bug;

feature分支是否推到遠(yuǎn)程,取決于你是否和你的小伙伴合作在上面開發(fā)。

總之,就是在Git中,分支完全可以在本地自己藏著玩,是否推送,視你的心情而定!

2.查看遠(yuǎn)程庫信息,使用git remote -v;

本地新建的分支如果不推送到遠(yuǎn)程,對其他人就是不可見的;

從本地推送分支,使用git push origin branch-name,如果推送失敗,先用git

pull抓取遠(yuǎn)程的新提交;

在本地創(chuàng)建和遠(yuǎn)程分支對應(yīng)的分支,使用git checkout -b branch-name origin/branch-name,本地和遠(yuǎn)程分支的名稱最好一致;

建立本地分支和遠(yuǎn)程分支的關(guān)聯(lián),使用git branch --set-upstream branch-name origin/branch-name;

從遠(yuǎn)程抓取分支,使用git pull,如果有沖突,要先處理沖突。

創(chuàng)建標(biāo)簽:

命令git

tag <tagname>用于新建一個(gè)標(biāo)簽,默認(rèn)為HEAD,也可以指定一個(gè)commit id;

命令git

tag -a <tagname> -m "blablabla..."可以指定標(biāo)簽信息;

命令git

tag可以查看所有標(biāo)簽。

操作標(biāo)簽:

命令git

push origin <tagname>可以推送一個(gè)本地標(biāo)簽;

命令git

push origin --tags可以推送全部未推送過的本地標(biāo)簽;

命令git

tag -d <tagname>可以刪除一個(gè)本地標(biāo)簽;

命令git

push origin :refs/tags/<tagname>可以刪除一個(gè)遠(yuǎn)程標(biāo)簽。


使用GitHub:

在GitHub上,可以任意Fork開源倉庫;

自己擁有Fork后的倉庫的讀寫權(quán)限;

可以推送pull request給官方倉庫來貢獻(xiàn)代碼。

?

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Part 1 Git基本介紹 版本控制基本功能 所有的版本控制系統(tǒng),只能跟蹤文本文件的改動,比如TXT文件,網(wǎng)頁,...
    妖國閱讀 399評論 0 0
  • Git是什么? Git是目前世界上最先進(jìn)的分布式版本控制系統(tǒng)(沒有之一)。作為一個(gè)開發(fā)者,git這樣的技能基本上是...
    ikook閱讀 3,022評論 12 129
  • git status:掌握工作時(shí)區(qū)狀態(tài) git diff:查看修改的內(nèi)容 git log:查看提交歷史 git r...
    Annzmy95閱讀 283評論 0 0
  • 本文主要介紹git分支的概念及常用分支操作。 分支的概念 所謂分支,可以理解成一個(gè)個(gè)相互獨(dú)立的工作空間,在每一個(gè)分...
    m2fox閱讀 92評論 0 0
  • 昨天開始學(xué)習(xí)git,摸索一天,記下若干要點(diǎn),權(quán)當(dāng)學(xué)習(xí)筆記,以備查漏補(bǔ)缺。 GIT配置 ** 安裝 **window...
    風(fēng)間莫一閱讀 271評論 2 1

友情鏈接更多精彩內(nèi)容