git教程——简单总结
1 創(chuàng)建版本庫:
- 初始化一個(gè)Git倉庫,使用git init命令。
- 添加文件到Git倉庫,分兩步:
?(1)使用命令git add <file>,注意,可反復(fù)多次使用,添加多個(gè)文件;
?(2)使用命令git commit -m <message>,完成。
2 時(shí)光穿梭:
- 要隨時(shí)掌握工作區(qū)的狀態(tài),使用git status命令。
- 如果git status告訴你有文件被修改過,用git diff?<file>可以查看修改內(nèi)容。
2.1 版本回退:
- HEAD指向的版本就是當(dāng)前版本,因此,Git允許我們在版本的歷史之間穿梭,使用命令git reset --hard commit_id。
??? 在Git中,用HEAD表示當(dāng)前版本, 上一個(gè)版本就是HEAD^,上上一個(gè)版本就是HEAD^^,當(dāng)然往上100個(gè)版本寫100個(gè)^比較容易數(shù)不過來,所以寫成HEAD~100。
- 穿梭前,用git log可以查看提交歷史,以便確定要回退到哪個(gè)版本。
- 要重返未來,用git reflog查看命令歷史,以便確定要回到未來的哪個(gè)版本。
2.2 管理修改:
- Git是跟蹤修改的,每次修改,如果不用git add到暫存區(qū),那就不會(huì)加入到commit中。
2.3 撤銷修改:
- 場景1:當(dāng)你改亂了工作區(qū)某個(gè)文件的內(nèi)容,想直接丟棄工作區(qū)的修改時(shí),用命令git checkout -- file。
git checkout其實(shí)是用版本庫里的版本替換工作區(qū)的版本,無論工作區(qū)是修改還是刪除,都可以“一鍵還原”。
- 場景2:當(dāng)你不但改亂了工作區(qū)某個(gè)文件的內(nèi)容,還添加到了暫存區(qū)時(shí),想丟棄修改,分兩步,第一步用命令git reset HEAD <file>,就回到了場景1,第二步按場景1操作。
用命令git reset HEAD <file>可以把暫存區(qū)的修改撤銷掉(unstage),重新放回工作區(qū);git reset命令既可以回退版本,也可以把暫存區(qū)的修改回退到工作區(qū)。
- 場景3:已經(jīng)提交了不合適的修改到版本庫時(shí),想要撤銷本次提交,參考版本回退一節(jié),不過前提是沒有推送到遠(yuǎn)程庫。
2.4 刪除文件:
- 命令git rm用于刪除一個(gè)文件。如果一個(gè)文件已經(jīng)被提交到版本庫,那么你永遠(yuǎn)不用擔(dān)心誤刪,但是要小心,你只能恢復(fù)文件到最新版本,你會(huì)丟失最近一次提交后你修改的內(nèi)容。
$ rm test.txt
3 分支管理
查看分支:git branch
創(chuàng)建分支:git branch <name>
切換分支:git checkout <name>
創(chuàng)建+切換分支:git checkout -b <name>
合并某分支到當(dāng)前分支:git merge <name>
刪除分支:git branch -d <name>
3.1解決沖突
當(dāng)Git無法自動(dòng)合并分支時(shí),就必須首先解決沖突。解決沖突后,再提交,合并完成。
解決沖突就是把Git合并失敗的文件手動(dòng)編輯為我們希望的內(nèi)容,再提交。
用git log --graph命令可以看到分支合并圖。
3.2分支管理策略
Git分支十分強(qiáng)大,在團(tuán)隊(duì)開發(fā)中應(yīng)該充分應(yīng)用。
合并分支時(shí),加上--no-ff參數(shù)就可以用普通模式合并,合并后的歷史有分支,能看出來曾經(jīng)做過合并,而fast forward合并就看不出來曾經(jīng)做過合并。
$ git merge --no-ff -m "merge with no-ff" dev Merge made by the 'recursive' strategy. readme.txt | 1 + 1 file changed, 1 insertion(+)3.3 Bug分支
修復(fù)bug時(shí),我們會(huì)通過創(chuàng)建新的bug分支進(jìn)行修復(fù),然后合并,最后刪除;
當(dāng)手頭工作沒有完成時(shí),先把工作現(xiàn)場git stash一下,然后去修復(fù)bug,修復(fù)后,再git stash pop,回到工作現(xiàn)場。
(用git stash list命令查看剛才保存的工作現(xiàn)場,Git把stash內(nèi)容存在某個(gè)地方了,但是需要恢復(fù)一下,有兩個(gè)辦法:
一是用git stash apply恢復(fù),但是恢復(fù)后,stash內(nèi)容并不刪除,你需要用git stash drop來刪除;
另一種方式是用git stash pop,恢復(fù)的同時(shí)把stash內(nèi)容也刪了。)
3.4 Feature分支
開發(fā)一個(gè)新feature,最好新建一個(gè)分支;
如果要丟棄一個(gè)沒有被合并過的分支,可以通過git branch -D <name>強(qiáng)行刪除。
3.5 多人協(xié)作
多人協(xié)作的工作模式通常是這樣:
如果git pull提示no tracking information,則說明本地分支和遠(yuǎn)程分支的鏈接關(guān)系沒有創(chuàng)建,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>。
小結(jié):
- 查看遠(yuǎn)程庫信息,使用git remote -v;
- 本地新建的分支如果不推送到遠(yuǎn)程,對(duì)其他人就是不可見的;
- 從本地推送分支,使用git push origin branch-name,如果推送失敗,先用git pull抓取遠(yuǎn)程的新提交;
- 在本地創(chuàng)建和遠(yuǎn)程分支對(duì)應(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,如果有沖突,要先處理沖突。
3.6 rebase
- rebase操作可以把本地未push的分叉提交歷史整理成直線;
- rebase的目的是使得我們在查看歷史提交的變化時(shí)更容易,因?yàn)榉植娴奶峤恍枰綄?duì)比。
4 標(biāo)簽管理
發(fā)布一個(gè)版本時(shí),我們通常先在版本庫中打一個(gè)標(biāo)簽(tag),這樣,就唯一確定了打標(biāo)簽時(shí)刻的版本。將來無論什么時(shí)候,取某個(gè)標(biāo)簽的版本,就是把那個(gè)打標(biāo)簽的時(shí)刻的歷史版本取出來。所以,標(biāo)簽也是版本庫的一個(gè)快照。
Git的標(biāo)簽雖然是版本庫的快照,但其實(shí)它就是指向某個(gè)commit的指針(跟分支很像對(duì)不對(duì)?但是分支可以移動(dòng),標(biāo)簽不能移動(dòng)),所以,創(chuàng)建和刪除標(biāo)簽都是瞬間完成的。
tag就是一個(gè)讓人容易記住的有意義的名字,它跟某個(gè)commit綁在一起。
4.1 創(chuàng)建標(biāo)簽
- 命令git tag <tagname>用于新建一個(gè)標(biāo)簽,默認(rèn)為HEAD,也可以指定一個(gè)commit id;
- 命令git tag -a <tagname> -m "blablabla..." 創(chuàng)建帶有說明的標(biāo)簽,用-a指定標(biāo)簽名,-m指定說明文字;
- 命令git tag可以查看所有標(biāo)簽。
- 命令git show <tagname>可以查看標(biāo)簽信息和說明文字。
4.2 操作標(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)簽。
一個(gè)本地庫同時(shí)關(guān)聯(lián)到github和碼云
使用多個(gè)遠(yuǎn)程庫時(shí),我們要注意,git給遠(yuǎn)程庫起的默認(rèn)名稱是origin,如果有多個(gè)遠(yuǎn)程庫,我們需要用不同的名稱來標(biāo)識(shí)不同的遠(yuǎn)程庫。
仍然以learngit本地庫為例,我們先刪除已關(guān)聯(lián)的名為origin的遠(yuǎn)程庫:
git remote rm origin然后,先關(guān)聯(lián)GitHub的遠(yuǎn)程庫:
git remote add github git@github.com:michaelliao/learngit.git注意,遠(yuǎn)程庫的名稱叫g(shù)ithub,不叫origin了。
接著,再關(guān)聯(lián)碼云的遠(yuǎn)程庫:
git remote add gitee git@gitee.com:liaoxuefeng/learngit.git同樣注意,遠(yuǎn)程庫的名稱叫g(shù)itee,不叫origin。
現(xiàn)在,我們用git remote -v查看遠(yuǎn)程庫信息,可以看到兩個(gè)遠(yuǎn)程庫:
git remote -v gitee??? git@gitee.com:liaoxuefeng/learngit.git (fetch) gitee??? git@gitee.com:liaoxuefeng/learngit.git (push) github??? git@github.com:michaelliao/learngit.git (fetch) github??? git@github.com:michaelliao/learngit.git (push)如果要推送到GitHub,使用命令:
git push github master如果要推送到碼云,使用命令:
git push gitee master這樣一來,我們的本地庫就可以同時(shí)與多個(gè)遠(yuǎn)程庫互相同步:
?
?
?
參考來源:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000
?
轉(zhuǎn)載于:https://www.cnblogs.com/zhenguoli/p/9139482.html
總結(jié)
以上是生活随笔為你收集整理的git教程——简单总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Could not read from
- 下一篇: PriorityBlockingQueu