目錄
- github 進階說明
- 前言
- 三個目錄樹
- 重置 git reset
- 增加路徑的reset
- 檢出 checkout
- 帶路徑的checkout
- 倉庫
- 數據對象
- 其他
- 資料
github 進階說明
前言
我們可以什么都不管,照搬命令來完成我們大部分git工作,但是如果想要進一步,就要深入理解git的實現原理,和底層機制。
三個目錄樹
- HEAD 倉庫指針
- index file 暫存區
- Working Directory 工作目錄
默認情況,頭指針會指向當前分支,當前分支指向當前目錄樹。所謂目錄樹簡而言之就是一個commit對象,保存了某個提交時刻的工作目錄內容的鏡像。而工作目錄就是當前文件內容。
狀態一:初始情況是三者相同。
狀態二:當你編輯了工作目錄下的內容,工作目錄和暫存區就不同。git status
會提示你git add
相關文件。
狀態三:git add
之后,暫存區和倉庫又不相同了,git status
提示你git commit
,當你git commit
之后,回到狀態一,倉庫就增加了一個新的版本,當前分支指針移動到新版本之上。
周而復始。
重置 git reset
但總有需要重置的時候:
git reset
移動當前分支指針(即間接改變HEAD)。
手段一:git reset --soft HEAD~
移動HEAD指針到HEAD~,這時倉庫和暫存區不同,暫存區和工作目錄相同,即狀態三。簡而言之,就是“撤銷”了上次的提交。
手段二:git reset --mixed HEAD~
移動HEAD指針到HEAD~,并重置暫存區。這時倉庫和暫存區相同,工作區和暫存區不同,即進入狀態二。--mixed是默認參數。
手段三:git reset --hard HEAD~
移動HEAD指針到HEAD~,并重置暫存區和工作區到當前HEAD版本。即狀態一。這是一條危險操作,因為你可能會丟失當前正在編輯而沒提交的所有內容。但這條命令也是真正完全的實現了跳躍版本,不會殘留任何一點當前版本的信息。
增加路徑的reset
reset可以增加路徑,這時的表現就是重置某個文件而已。并不會改動HEAD指針。
git reset -- file.txt
重置暫存區file.txt文件狀態。簡而言之,就是git add
的反向操作。
你還能指定暫存區重置到哪個版本git reset 234b file.txt
。
檢出 checkout
checkout和reset命令很相似,也是操控三個目錄樹。差別是checkout 改變HEAD本身,reset是改變當前被HEAD指向的分支。務必理解這個二重指針的結構。
比如HEAD 指向master,reset 會改變master,HEAD不變。而checkout 會直接改變HEAD,master不變。雖然表面現象上來說很多時候表現是差不多的,因為當前用戶可能只會觀察到三棵樹的變化,而沒有留意指針的變化。
git checkout develop
從master分支切換到develop分支,并重置工作區和暫存區,進入狀態一。
帶路徑的checkout
類似帶路徑的reset,并不會改變HEAD,不同點它重置暫存區,同時也重置工作區。
git checkout -- file.txt
用當前HEAD指向的目錄樹中的file.txt鏡像重置暫存區和工作區。
倉庫
- 純倉庫。
git init --bare
創建一個純倉庫,只是用來存儲倉庫數據而不是用來工作的。比如用來做服務器遠端倉庫,本地倉庫的備份。 - 空倉庫。
git init
創建一個空倉庫
倉庫內容:ls -F1 .git
branches/ #分支
COMMIT_EDITMSG
COMMIT_EDITMSG.save
config #設置
description #GitWeb使用
FETCH_HEAD
gitk.cache
HEAD #頭指針
hooks/ #鉤子
index #暫存區
info/ #全局排除模式,類似.gitignore
logs/
objects/ #數據
ORIG_HEAD
refs/ #各種commit 指針
數據對象
git hash-object
任何對象都可以用哈希值加入倉庫索引git cat-file
用哈希值搜索倉庫內對象git update-index --add --cachinfo 100644
更新暫存區對象git write-tree
將暫存區寫入樹對象git read-tree --prefix=dir
加入子樹,前綴dirgit commit-tree c03ca4
用樹對象生成提交對象git log --stat
查看提交對象歷史信息git fsck --full
查看沒有引用的對象git gc
壓縮對象庫git count-objects -v
查看空間暫用統計git prune --expire now
立即清除所有不被引用的對象(因為試驗,生成了錯誤的對象,但是要清理非常非常麻煩,最后靠這條命令成功清理了)git reflog expire --expire-unreachable=0 --all
清理操作記錄,這是對象有可能被引用的地方
其他
git config core.autocrlf true
自動轉換換行格式。
資料
git社區參考書:http://gitbook.liuhui998.com/