git學習筆記——本地

小追兵專欄

一、簡介

svn的時代慢慢的走到向尾聲,git正在慢慢取代svn。

我也從svn換成Git作為版本控制軟件了。下面我們簡單的學習下Git的使用。

這里我們是當成一片學習筆記。適用于初學者。

  • 什么是Git?Git是一款免費、開源的分布式版本控制系統。不論怎么形容,它就是用來做版本控制的。

  • 什么是分布式:簡單粗暴的理解為分散的,分開的,每一個個體是單獨的,這些單獨個體也可組合為一個整體的大系統。

  • 舉例來說:這里Git是分布式,就是每個用戶計算機都是一個版本控制庫,可以不依賴中央服務器。而相對svn就是集中式版本控制,每個計算機不能作為一個單獨的版本控制庫,只能依賴中央服務器。

這里盜用別人一張圖:

圖片發自簡書App

大神也對圖中的錯誤進行了如下更新:

1.更改了一個錯別字,git fetch操作的“單”=>“但”。由@leky指出。

2.reset --head更改為reset --hard。由@dtopn指出。

3.分支篇新增git rebase $other_branch操作。由@dtopn提出。

下面用到的git命令:

 git config --global user.name "Your Name"
 git config --global user.email "email@example.com"
 
 cd gittest
 touch README.txt
 git add -A
 git add --all
git add README.txt
git commit -m "readme.txt第一次提交"
git diff README.txt
git log
git log –pretty=oneline
簡寫為
git log --oneline
//由@lovexiaov提供的簡寫命令
git reset  --hard HEAD^
git reset  --hard HEAD~100
git reflog
git reset  --hard  c8dd*** 版本號
git checkout  --  readme.txt

如果你都比較熟悉,可以不用接著往后看了。

這里我們以Mac電腦作為演示,Windows可以下載 msysgit,打開Git Bash,其他完全一樣。

二、配置標識

下來我們說說git的第一條命令:
在mac的 終端 下面輸入:

 git config --global user.name "Your Name"
 git config --global user.email "email@example.com"

git作為一個分布式版本管理系統,它需要每一個用戶的一個標識,上面填寫的"Your Name""email@example.com"就是我們自己的唯一標識。

--global這個參數讓我們的標識在這臺電腦的所有位置都生效,如果我們需要對某個單獨的庫進行配置,也是可以的。

三、創建版本庫

1、如何管理我們的一個項目呢?假定我們需要管理的目錄是gittest文件夾,如圖:


這里寫圖片描述

2、在終端中,我們用cd gittest命令進入我們的項目目錄gittest,如圖:

這里寫圖片描述

現在我們已經在gittest目錄下了,接下來,我們用如下命令創建版本庫:

git init
這里寫圖片描述

這時git會在這個目錄下創建一個.git文件,這就是我們的版本庫。我們可以通過ls -a命令查看.git是否真的被創建。.git是用來管理和跟蹤文件的庫,沒事不要對.git進行手動刪除或修改,這樣會破壞版本控制的結構,導致版本庫被破壞,如圖已被創建:

這里寫圖片描述

現在我們創建一個README.txt文件假設為我們項目文件,把這個文件添加到我們的版本庫中。在這里我用touch README.txt命令創建一個README.txt文件,把它作為我們的管理對象。如圖:

這里寫圖片描述

我們去文件夾中查看,文件已經創建,如圖:


這里寫圖片描述

現在把這個txt文件作為我們項目文件,添加到版本庫中進行管理。

命令:

git add --all

或者

git add -A

這里是把我們項目目錄gittest下面的所有文件添加到了Git的緩存區。
也可以單獨添加需要控制的文件:

git add README.txt

沒有任何提示,說明添加成功。
如圖:


這里寫圖片描述

命令:

git commit -m "readme.txt第一次提交"

這里我們將README.txt文件提交到了倉庫,如圖:


這里寫圖片描述

補充這里可以看到,git還吧一個.DS_Store的文件提交到了版本庫,.DS_Store文件是mac系統的文件夾下的隱藏文件,這是因為我用的是git add --all命令,所以把目錄下的所有文件都提交了。

我們看看還有什么文件沒有被提交,用git status命令,如圖:

這里寫圖片描述

可以看到,已經沒有可commit的文件了。

可是我們現在對README.txt文件做出修改,我們添加了內容111……和222……如圖:


這里寫圖片描述

現在我們用git status查看git的狀態,如圖:

這里寫圖片描述

git告訴我們,文件能容被修改,但沒有提交。

我們通過git diff README.txt查看文件,如圖:

這里寫圖片描述

可以看到我們的README.txt添加了兩行新內容。

現在我們對修改后的文件進行提交,和前面一樣:

git add -A
git commit -m "第二次提交,添加了內容111和222"

之后我們用git status看看git的狀態,還有什么沒有提交,如圖:

這里寫圖片描述

學會了這個,我們繼續修改README.txt文件內容,增加333……,并且提交,如圖:


這里寫圖片描述

這里寫圖片描述

三、版本回退

接下來,我們做版本回退,我們剛才增加了333……,可是發現不理想,或者有重大問題,舍棄不需要增加333……后的這個版本了,我們想退回222……那里。

我們現在可以使用命令 git log 查看提交的日志:如圖

這里寫圖片描述

可以看出,我們對一共提交了三次。亦可以看出提交的順序,
如果看著不爽,也可以用

git log –pretty=oneline
簡寫
git log --oneline
//由@lovexiaov提供的簡寫命令

結果如圖:


這里寫圖片描述

這樣有用寫信就顯示在一行了,前面紅色圈里的數字符號,是只版本號,后面箭頭指的是提交時寫的提交信息。

現在我們用下面命令:

git reset  --hard HEAD^

是指:退回上一個版本,這里我們的上一個版本是只有兩行,第一行111……第二行是222……,第三行的333……還沒有添加。讓我們看看效果吧!如圖:


這里寫圖片描述

文件已經是下圖的樣子了:


這里寫圖片描述

回退之后,用git log可以看到如下內容:

這里寫圖片描述

可以看到,333……已經不再了。一次類推,要回退上上個版本就是HEAD^^,那上上上個版本就是HEAD^^^,然后如果有100個版本,你不介意就一直接 ^ 吧。當然也可以用更方便的方法了:

git reset  --hard HEAD~100

回退100個版本。

我們還有一種回退方法,指定版本號回退。假定我現在又想退回添加333……的那個版本去,我們用git log查看了,只能看到第一次,和第二次提交的內容,第三次的我們看不到,我們該怎么做呢?

git reflog

這樣我們如同看到了三個版本的版本號:


這里寫圖片描述

我們已經看到了我們第三次提交的版本號了:

git reset  --hard  c8ddd30

這里的“c8ddd30”是版本號,我們用git reflog可以查看

這里寫圖片描述

現在查看下README.txt,發現文件中的內容有回到了三行。如圖:


這里寫圖片描述

·

五、工作區和暫存區的比較和理解

    工作區:電腦上項目的目錄,比如目錄下testgit里的文件README.txt(.git隱藏目錄版本庫除外),還有之后在目錄中增加的文件,和子目錄都是工作區。

  版本庫 (Repository) : 我們git init命令后,在gittest目錄下生成的.git就是版本庫。它不是工作區,.git里面存了很多東西,其中最重要的就是stage(暫存區),還有Git為我們自動創建了第一個分支master,以及指向master的一個指針HEAD。

我們前面說過使用Git提交文件到版本庫有兩步:

  • 第一步:是使用 git add 把文件添加進去,實際上就是把文件添加到暫存區。

  • 第二步:使用git commit提交更改,實際上就是把暫存區的所有內容提交到當前分支上。

現在我們做了下面操作:
我們在前面333……的基礎上有增加了一行444……,可是還沒等我們提交的時候,我們想放棄這次修改,不要增加的444……了。這里我們要進行撤銷操作:

1、手動刪除添加的444……內容。
2、版本回退到上一個版本。

git reset  --hard HEAD^

3、放棄此次編輯,把工作區做的修改全部撤銷。

git checkout  --  readme.txt

三個方法根據需要,和方便性,可以自行選擇。

注意

    命令git checkout -- readme.txt 中的 -- 很重要,如果沒有 -- 的話,那么命令變成創建分支了。

現在我們想刪除項目中的文件b.txt,項目中有些文件我們用不到了,我們需要刪除,以保證項目的感覺。

1、我直接在gittest文件目錄中把文件b.txt刪了,或者使用如上rm命令:rm b.txt

2、如果想把庫中的b.txt也刪除了,那我們只要commit已經刪除過b.txt的項目到庫中就好了。因為提交的項目里沒有b.txt,所以也就等等刪除了庫中的b.txt.

3、如果沒commit前,想回復剛才刪除的工作區中的b.txt,用將庫里的checout一份。

git checkout  -- b.txt

·
·

遠程庫的學習筆記,會在下一篇中詳細說明。

最后:有需要Shadowsock翻墻賬號可以私聊。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,619評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,155評論 3 425
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,635評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,539評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,255評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,646評論 1 326
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,655評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,838評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,399評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,146評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,338評論 1 372
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,893評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,565評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,983評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,257評論 1 292
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,059評論 3 397
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,296評論 2 376

推薦閱讀更多精彩內容