1 建立版本庫:git
(1)使用命令git add <file>,注意,可反覆屢次使用,添加多個文件;github
(2)使用命令git commit -m <message>,完成。app
2 時光穿梭:fetch
2.1 版本回退:指針
HEAD
指向的版本就是當前版本,所以,Git容許咱們在版本的歷史之間穿梭,使用命令git reset --hard commit_id
。 在Git中,用HEAD
表示當前版本, 上一個版本就是HEAD^
,上上一個版本就是HEAD^^
,固然往上100個版本寫100個^
比較容易數不過來,因此寫成HEAD~100
。code
git log
能夠查看提交歷史,以便肯定要回退到哪一個版本。git reflog
查看命令歷史,以便肯定要回到將來的哪一個版本。2.2 管理修改:orm
git add
到暫存區,那就不會加入到commit
中。2.3 撤銷修改:blog
git checkout
實際上是用版本庫裏的版本替換工做區的版本,不管工做區是修改仍是刪除,均可以「一鍵還原」。開發
用命令git reset HEAD <file>
能夠把暫存區的修改撤銷掉(unstage),從新放回工做區;git reset
命令既能夠回退版本,也能夠把暫存區的修改回退到工做區。rem
2.4 刪除文件:
git rm
用於刪除一個文件。若是一個文件已經被提交到版本庫,那麼你永遠不用擔憂誤刪,可是要當心,你只能恢復文件到最新版本,你會丟失最近一次提交後你修改的內容。$ rm test.txt
3 分支管理
查看分支:git branch
建立分支:git branch <name>
切換分支:git checkout <name>
建立+切換分支:git checkout -b <name>
合併某分支到當前分支:git merge <name>
刪除分支:git branch -d <name>
3.1解決衝突
當Git沒法自動合併分支時,就必須首先解決衝突。解決衝突後,再提交,合併完成。
解決衝突就是把Git合併失敗的文件手動編輯爲咱們但願的內容,再提交。
用git log --graph命令能夠看到分支合併圖。
3.2分支管理策略
Git分支十分強大,在團隊開發中應該充分應用。
合併分支時,加上--no-ff參數就能夠用普通模式合併,合併後的歷史有分支,能看出來曾經作過合併,而fast forward合併就看不出來曾經作過合併。
$ "merge with no-ff"git merge --no-ff -mdev
Merge'recursive'made by thestrategy.
1readme.txt |+
11file changed,insertion(+)
3.3 Bug分支
修復bug時,咱們會經過建立新的bug分支進行修復,而後合併,最後刪除;
當手頭工做沒有完成時,先把工做現場git stash
一下,而後去修復bug,修復後,再git stash pop
,回到工做現場。
(用git stash list
命令查看剛纔保存的工做現場,Git把stash內容存在某個地方了,可是須要恢復一下,有兩個辦法:
一是用git stash apply
恢復,可是恢復後,stash內容並不刪除,你須要用git stash drop
來刪除;
另外一種方式是用git stash pop
,恢復的同時把stash內容也刪了。)
3.4 Feature分支
開發一個新feature,最好新建一個分支;
若是要丟棄一個沒有被合併過的分支,能夠經過git branch -D <name>
強行刪除。
3.5 多人協做
多人協做的工做模式一般是這樣:
若是git pull提示no tracking information,則說明本地分支和遠程分支的連接關係沒有建立,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>。
小結:
3.6 rebase
4 標籤管理
發佈一個版本時,咱們一般先在版本庫中打一個標籤(tag),這樣,就惟一肯定了打標籤時刻的版本。未來不管何時,取某個標籤的版本,就是把那個打標籤的時刻的歷史版本取出來。因此,標籤也是版本庫的一個快照。
Git的標籤雖然是版本庫的快照,但其實它就是指向某個commit的指針(跟分支很像對不對?可是分支能夠移動,標籤不能移動),因此,建立和刪除標籤都是瞬間完成的。
tag就是一個讓人容易記住的有意義的名字,它跟某個commit綁在一塊兒。
4.1 建立標籤
-a
指定標籤名,-m
指定說明文字;git show <tagname>
能夠查看標籤信息和說明文字。$ 0 默認標籤是打在最新提交的commit上git tag v1.
$ 09找到歷史提交的commit id,而後打上標籤git tag v.f52c633 也能夠
4.2 操做標籤
一個本地庫同時關聯到github和碼雲
使用多個遠程庫時,咱們要注意,git給遠程庫起的默認名稱是origin
,若是有多個遠程庫,咱們須要用不一樣的名稱來標識不一樣的遠程庫。
仍然以learngit
本地庫爲例,咱們先刪除已關聯的名爲origin
的遠程庫:
git remote rm origin
而後,先關聯GitHub的遠程庫:
@githubcom:git remote add github git.michaelliao/learngit.git
注意,遠程庫的名稱叫github
,不叫origin
了。
接着,再關聯碼雲的遠程庫:
@giteecom:git remote add gitee git.liaoxuefeng/learngit.git
一樣注意,遠程庫的名稱叫gitee
,不叫origin
。
如今,咱們用git remote -v
查看遠程庫信息,能夠看到兩個遠程庫:
git remote -v
@giteecom:gitee git.liaoxuefeng/learngit.git (fetch)
@giteecom:gitee git.liaoxuefeng/learngit.git (push)
@githubcom:github git.michaelliao/learngit.git (fetch)
@githubcom:github git.michaelliao/learngit.git (push)
若是要推送到GitHub,使用命令:
git push github master
若是要推送到碼雲,使用命令:
git push gitee master
這樣一來,咱們的本地庫就能夠同時與多個遠程庫互相同步:
參考來源:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000