標(biāo)簽(空格分隔): Git
安裝
- Linux:sudo apt-get install git
- Mac: 1.homebrew 2.Xcode集成Git
- Windows:msysgit是Windows版的Git弧可,從http://msysgit.github.io/下載劣欢,用git bash打開
創(chuàng)建版本庫
版本庫又名倉庫,英文名repository
創(chuàng)建版本庫步驟:
選擇一個合適的地方校套,創(chuàng)建一個空目錄
$ mkdir learngit $ cd learngit $ pwd /Users/michael/learngit
使用
git init
命令把這個目錄變成Git可以管理的倉庫
把文件添加到版本庫
注意
所有的版本控制系統(tǒng)牧抵,其實(shí)只能跟蹤文本文件的改動犀变,比如TXT文件,網(wǎng)頁蠢正,所有的程序代碼等等省店,Git也不例外。版本控制系統(tǒng)可以告訴你每次的改動懦傍,比如在第5行加了一個單詞“Linux”粗俱,在第8行刪了一個單詞“Windows”。而圖片签财、視頻這些二進(jìn)制文件,雖然也能由版本控制系統(tǒng)管理,但沒法跟蹤文件的變化烛愧,只能把二進(jìn)制文件每次改動串起來,也就是只知道圖片從100KB改成了120KB慎冤,但到底改了啥,版本控制系統(tǒng)不知道蚁堤,也沒法知道但狭。
不幸的是,Microsoft的Word格式是二進(jìn)制格式呈队,因此唱歧,版本控制系統(tǒng)是沒法跟蹤Word文件的改動的,前面我們舉的例子只是為了演示几于,如果要真正使用版本控制系統(tǒng)沿彭,就要以純文本方式編寫文件得运。
編碼
因?yàn)槲谋臼怯芯幋a的,比如中文有常用的GBK編碼熔掺,日文有Shift_JIS編碼置逻,如果沒有歷史遺留問題,強(qiáng)烈建議使用標(biāo)準(zhǔn)的UTF-8編碼鬓催,所有語言使用同一種編碼,既沒有沖突倍靡,又被所有平臺所支持课舍。
Windows的記事本
使用Windows的童鞋要特別注意:
千萬不要使用Windows自帶的記事本編輯任何文本文件。原因是Microsoft開發(fā)記事本的團(tuán)隊(duì)使用了一個非常弱智的行為來保存UTF-8編碼的文件捡需,他們自作聰明地在每個文件開頭添加了0xefbbbf(十六進(jìn)制)的字符筹淫,你會遇到很多不可思議的問題损姜,比如,網(wǎng)頁第一行可能會顯示一個“?”捐川,明明正確的程序一編譯就報(bào)語法錯誤古沥,等等娇跟,都是由記事本的弱智行為帶來的。建議你下載Notepad++代替記事本苞俘,不但功能強(qiáng)大吃谣,而且免費(fèi)!記得把Notepad++的默認(rèn)編碼設(shè)置為UTF-8 without BOM即可岗憋。
添加步驟
- 編寫一個文件仔戈,放到learngit目錄下
- 用命令
git add readme.txt
告知git有文件添加:
$ git add readme.txt
- 用命令
git commit
告知git,把文件提交到倉庫:
$ git commit -m "wrote a readme file"
簡單解釋一下
git commit
命令,-m
后面輸入的是本次提交的說明晋修,可以輸入任意內(nèi)容,當(dāng)然最好是有意義的墓卦,這樣你就能從歷史記錄里方便地找到改動記錄。
git commit
命令執(zhí)行成功后會告訴你溅漾,1個文件被改動(我們新添加的readme.txt文件)著榴,插入了兩行內(nèi)容(readme.txt有兩行內(nèi)容)脑又。
為什么Git添加文件需要
add
问麸,commit
一共兩步呢钞翔?因?yàn)?code>commit可以一次提交很多文件,所以你可以多次add
不同的文件哮笆,比如:
$ git add file1.txt
$ git add file2.txt
$ git add file3.txt
$ git commit -m "add 3 files."
時光穿梭機(jī)
- 版本回退
- 工作區(qū)和暫存區(qū)
- 管理修改
- 撤銷修改
- 刪除文件
如何提交修改
如果修改了文件稠肘,比如在git_example_1.txt中修改了如下內(nèi)容:
Git is a distributed version control system.
Git is free software.
然后運(yùn)行git status
查看結(jié)果萝毛,顯示會如下
$ git status
# On branch master
# Changes not staged for commit:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: readme.txt
#
no changes added to commit (use "git add" and/or "git commit -a")
git status
命令可以讓我們時刻掌握倉庫當(dāng)前的狀態(tài)笆包,上面的命令告訴我們,readme.txt被修改過了歉胶,但還沒有準(zhǔn)備提交的修改秧了。
此外可以使用git diff
命令來查看具體修改了什么內(nèi)容。
$ git diff readme.txt
diff --git a/readme.txt b/readme.txt
index 46d49bf..9247db6 100644
--- a/readme.txt
+++ b/readme.txt
@@ -1,2 +1,2 @@
-Git is a version control system.
+Git is a distributed version control system.
Git is free software.
知道了對文件進(jìn)行了什么修改帝嗡,就可以把它提交到倉庫了哟玷,使用git add
一也。
git add git_example_1.txt
小結(jié):
- 要隨時掌握工作區(qū)的狀態(tài),使用
git status
命令 - 如果
git status
告訴你有文件被修改過抑月,用git diff
可以查看修改內(nèi)容谦絮。