Git使用指南(未完待續(xù))

標(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)建版本庫步驟:

  1. 選擇一個合適的地方校套,創(chuàng)建一個空目錄
    $ mkdir learngit $ cd learngit $ pwd /Users/michael/learngit

  2. 使用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即可岗憋。

添加步驟

  1. 編寫一個文件仔戈,放到learngit目錄下
  2. 用命令git add readme.txt告知git有文件添加:
$ git add readme.txt
  1. 用命令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)容谦絮。

版本回退

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末洁仗,一起剝皮案震驚了整個濱河市赠潦,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌她奥,老刑警劉巖哩俭,帶你破解...
    沈念sama閱讀 222,807評論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異你踩,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)带膜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,284評論 3 399
  • 文/潘曉璐 我一進(jìn)店門膝藕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來芭挽,“玉大人,你說我怎么就攤上這事蠕趁“陈” “怎么了?”我有些...
    開封第一講書人閱讀 169,589評論 0 363
  • 文/不壞的土叔 我叫張陵昙篙,是天一觀的道長腊状。 經(jīng)常有香客問我,道長苔可,這世上最難降的妖魔是什么缴挖? 我笑而不...
    開封第一講書人閱讀 60,188評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮焚辅,結(jié)果婚禮上醇疼,老公的妹妹穿的比我還像新娘。我一直安慰自己法焰,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,185評論 6 398
  • 文/花漫 我一把揭開白布倔毙。 她就那樣靜靜地躺著埃仪,像睡著了一般。 火紅的嫁衣襯著肌膚如雪陕赃。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,785評論 1 314
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼泛释。 笑死,一個胖子當(dāng)著我的面吹牛注竿,可吹牛的內(nèi)容都是我干的裙顽。 我是一名探鬼主播机蔗,決...
    沈念sama閱讀 41,220評論 3 423
  • 文/蒼蘭香墨 我猛地睜開眼牙言,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了蚕断?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,167評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后带斑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,698評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡醋安,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,767評論 3 343
  • 正文 我和宋清朗相戀三年所计,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片踪栋。...
    茶點(diǎn)故事閱讀 40,912評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡予颤,死狀恐怖党饮,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情荞驴,我是刑警寧澤霹娄,帶...
    沈念sama閱讀 36,572評論 5 351
  • 正文 年R本政府宣布枕磁,位于F島的核電站茸苇,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏腻暮。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,254評論 3 336
  • 文/蒙蒙 一霍狰、第九天 我趴在偏房一處隱蔽的房頂上張望康震。 院中可真熱鬧腿短,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,746評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至弛随,卻和暖如春舀透,著一層夾襖步出監(jiān)牢的瞬間惑芭,已是汗流浹背婴渡。 一陣腳步聲響...
    開封第一講書人閱讀 33,859評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 49,359評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親几缭。 傳聞我的和親對象是個殘疾皇子年栓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,922評論 2 361

推薦閱讀更多精彩內(nèi)容