見過最好的git入門教程

今天找到一篇見過最好的git入門教程git

http://lostechies.com/joshuaflanagan/2010/09/03/use-gitk-to-understand-git/工具

 

粘帖一些命令fetch

1. git add 添加文件到staged area.
2. git commit 會commit staged file ,有幾個選項比較重要:-a 跳過staged area,直接commit,後面加文件名也會使那個文件跳過stage,直接commit。可是前提是文件已經在index中了,新文件不會自動加入。
3.git status 查看從上次commit到目前的變化,git diff會更詳細,可是它只包含應該要包含在staged area中卻還未包含進去的變化,git diff --staged則列出來從上次commit到staged area的變化。
4. .gitignore文件能夠設置哪些文件被排除進去,一般能夠設.o, .a等文件。
5. git rm 用來remove文件。
6. git mv能夠用來重命名文件。
7. git log用來查看日誌,git log -p查看詳細,gitk 是個圖形化的查看工具。
8.Unstaging a Staged File能夠用git reset HEAD <file>。 Unmodifying a Modified File能夠用git checkout -- <file>。 git commit --amend用來取消上次的commit。
9. git remote顯示全部的remote(加-v顯示詳細信息)。
 git remote add [shortname] [url]用來添加remote。 git fetch [remote-name]只會pull下來所有的更動,但不會自動merge,可是git pull會自動merge。 git remote show [remote-name]能夠看到一個remote的詳細信息。 git remote rename用來改變一個remote的名字。 git remote rm刪除一個remote。
10.git tag列出全部的tag。git show tag-name能夠查看tag詳細信息。git tag [-a] tag-name -m message [commit-checksum]若是有-a 就添加一個annotated tag,若是沒有-a,就添加一個lightweight tag,若是後面要在某個commit以後添加一個tag,就加上checksum好了。 git push有個選項 --tags會把tags信息也push上去。

11.
 git branch testing添加一個testing的branch. git checkout testing切換到testing branch. 
12. 切換branch的時候,當前的branch不能有和要切換過去的branch衝突的uncommitted changes.
13. git merge branch-name 將branch-name merge到當前branch.若是有conflict,能夠用status查看狀態,解決conflict以後用add 通知git已經解決。而後用commit commit the merge。
14.
   git branch -d branch-name,可是這個branch必須被所有merge到HEAD中了。若是選項是-D的化,就無論它的merge status了。
15. git branch --merged只顯示被HEAD徹底包含的branch,--no-merged只顯示沒被HEAD徹底包含的branch。
16.
 git push (remote) (branch)把本地某個branch push到remote上去。 git push (remote) (local-branch-name):(remote-branch-name)能夠把本地branch push到remote branch上去。
17.git fetch 下載下來的branch不能edit,必需要手動merge到本地branch以後才能夠edit。
   $ git checkout -b local-branch-name remote-name/remote-branch-name 能夠把server上的branch下載下來,而且能夠直接edit。
18.
 Tracking Branches裏面能夠沒必要在pull和push後面加remote參數。git branch -r列出remote tracking branches.
19. git push [remotename] :[remote-branch]刪除掉某個remote branch。
20. rebase能夠得到和merge同樣的效果,可是log記錄更好,由於看起來沒有分支。
 git rebase --onto newbase upstream branch會把從upstream到branch的改動rebase到newbase上去。git rebase basebranch topicbranch會把topicbranch rebase到basebranch上。
21. 
Do not rebase commits that you have pushed to a public repository.

22.git fetch默認會獲取repo全部branch的進度,除非指定哪一個branch。git push能夠將某個branch push到repo中去。
url

相關文章
相關標籤/搜索