GIT 深入探索

git

1.創(chuàng)建倉庫路徑

$ mkdir learngit
$ cd learngit
$ pwd
/Users/michael/learngit

2.初始化倉庫

$ git init
Initialized empty Git repository in /Users/michael/learngit/.git/
bfdeMacBook-Pro:lib bf$ ls -ah
.   ..  .git
bfdeMacBook-Pro:lib bf$
  • 查看隱藏文件舌界,多了.git
git add 
git commit 
git diff 查看文件的difference
git status

3.版本回退

git log
git log --pretty=oneline  減少輸出信息
屏幕快照 2017-01-20 下午3.15.02.png
HEAD 當(dāng)前版本
HEAD^ 上一個(gè)版本
HEAD^^ 上上個(gè)版本
HEAD~100 往上100個(gè)版本
  • 回到上一個(gè)版本
bfdeMacBook-Pro:lib bf$ git reset --hard HEAD^
HEAD is now at e4a2839 fasdf
bfdeMacBook-Pro:lib bf$

--hard?

bfdeMacBook-Pro:lib bf$ git reset --hard f1708d0
HEAD is now at f1708d0 dsfa
bfdeMacBook-Pro:lib bf$ git log
commit f1708d0dd521f878b07a276e8796a4237b391be2
Author: zbf <bf@bfdeMacBook-Pro.local>
Date:   Fri Jan 20 15:06:23 2017 +0800

    dsfa

commit e4a28390bd0b72c5414d4bf67d7b07d3c80fda59
Author: zbf <bf@bfdeMacBook-Pro.local>
Date:   Fri Jan 20 15:01:59 2017 +0800

    fasdf
bfdeMacBook-Pro:lib bf$
  • 回退到上一個(gè)版本后井联,最后一個(gè)版本會(huì)在log里消失缠导,但可以使用 git reset --hard f1708d0 回到制定版本削罩,commit id 前幾位就可以了沦泌,git會(huì)自動(dòng)查找糊昙,

 現(xiàn)在,你回退到了某個(gè)版本谢谦,關(guān)掉了電腦释牺,第二天早上就后悔了,想恢復(fù)到新版本怎么辦回挽?找不到新版本的commit id怎么辦没咙?
在Git中,總是有后悔藥可以吃的千劈。當(dāng)你用* git reset --hard HEAD^*回退到**版本時(shí)祭刚,再想恢復(fù)到append GPL,就必須找到append GPL的commit id墙牌。Git提供了一個(gè)命令git reflog用來記錄你的每一次命令:
bfdeMacBook-Pro:lib bf$ git reflog
f1708d0 HEAD@{0}: reset: moving to f1708d0
e4a2839 HEAD@{1}: reset: moving to HEAD^
f1708d0 HEAD@{2}: commit: dsfa
e4a2839 HEAD@{3}: commit (initial): fasdf
bfdeMacBook-Pro:lib bf$
  • 重返未來涡驮,用git reflog查看歷史,以便確定要回到未來的那個(gè)版本喜滨。

管理版本

bfdeMacBook-Pro:lib bf$ git diff HEAD -- aaa.txt
diff --git a/aaa.txt b/aaa.txt
index a79beab..6f150ec 100644
--- a/aaa.txt
+++ b/aaa.txt
@@ -1,2 +1,3 @@
 helloworl
 fdsaffd
+fdaf
bfdeMacBook-Pro:lib bf$
  • git diff HEAD -- aaa.txt用來查看工作區(qū)與版本庫最新版的差別

撤銷修改

bfdeMacBook-Pro:lib bf$ git checkout -- aaa.txt
  • git checkout -- aaa.txt 撤銷對文件的修改 總之捉捅,就是讓這個(gè)文件回到最近一次 git commitgit add時(shí)的狀態(tài)。 -- 很重要
bfdeMacBook-Pro:lib bf$ git status
On branch master
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

    modified:   aaa.txt

bfdeMacBook-Pro:lib bf$ git reset HEAD aaa.txt
Unstaged changes after reset:
M   aaa.txt
bfdeMacBook-Pro:lib bf$ ls
aaa.txt
bfdeMacBook-Pro:lib bf$ 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:   aaa.txt

no changes added to commit (use "git add" and/or "git commit -a")
bfdeMacBook-Pro:lib bf$
  • git reset HEAD aaa.txt 把已添加暫存區(qū)的文件撤銷

刪除文件

$ git rm test.txt 從版本庫中刪除虽风,可以恢復(fù)
rm 'test.txt'
$ git commit -m "remove test.txt"
[master d17efd8] remove test.txt
 1 file changed, 1 deletion(-)
 delete mode 100644 test.txt
  • 這樣就刪除了锯梁,如果刪錯(cuò)了:
git checkout test.txt //就恢復(fù)了

遠(yuǎn)程倉庫

$ ssh-keygen -t rsa -C "youremail@example.com"

分支操作

  • 創(chuàng)建新分支
bfdeMacBook-Pro:lib bf$ git checkout -b dev
Switched to a new branch 'dev'
bfdeMacBook-Pro:lib bf$
  • 提交到新分支
bfdeMacBook-Pro:lib bf$ git commit -m "D"
On branch dev
nothing to commit, working tree clean
bfdeMacBook-Pro:lib bf$
  • 切換到master分支
bfdeMacBook-Pro:lib bf$ git checkout master
Switched to branch 'master'
bfdeMacBook-Pro:lib bf$
  • 合并
bfdeMacBook-Pro:lib bf$ git merge dev
Already up-to-date.
bfdeMacBook-Pro:lib bf$
  • 刪除分支
bfdeMacBook-Pro:lib bf$ git branch -d dev
Deleted branch dev (was 78b0a3a).
bfdeMacBook-Pro:lib bf$
  • 小結(jié)
小結(jié)

Git鼓勵(lì)大量使用分支:

查看分支:git branch

創(chuàng)建分支:git branch <name>

切換分支:git checkout <name>

創(chuàng)建+切換分支:git checkout -b <name>

合并某分支到當(dāng)前分支:git merge <name>

刪除分支:git branch -d <name>

解決沖突

  • 創(chuàng)建新分支
git checkout -b new
Switched to a new branch 'new'
bfdeMacBook-Pro:lib bf$
  • 修改內(nèi)容即碗,重新提交
  • 切換到 master
  • 修改內(nèi)容,提交
  • 執(zhí)行命令合并,無法快速合并
bfdeMacBook-Pro:lib bf$ git merge new
Auto-merging aaa.txt
CONFLICT (content): Merge conflict in aaa.txt
Automatic merge failed; fix conflicts and then commit the result.
bfdeMacBook-Pro:lib bf$
屏幕快照 2017-01-23 上午10.40.16.png
  • Git用<<<<<<<陌凳,=======剥懒,>>>>>>>標(biāo)記出不同分支的內(nèi)容,我們手動(dòng)解決沖突合敦,保存提交
屏幕快照 2017-01-23 上午10.45.19.png
  • 用帶參數(shù)的git log也可以看到分支的合并情況:
bfdeMacBook-Pro:lib bf$ git log --graph --pretty=oneline --abbrev-commit
*   9c906c7 new
|\
| * b5c069c fsdafa
* | 7601d44 dsfafdsfaadsfsdf
|/
*   ddd78ff das
|\
| * bd2e8d0 fsd
| * 7840261 fdsaf
| * bf660c7 AND simple
* | 79e9a59 dsfdasf
* | 1163c06 simple
|/
* 78b0a3a fasf
* 4c929de fdsfa
* 39c936f dsaf
* d0462d7 dfafs
* 6cef978 remove test.txt
* 76f6daf add test
* 49dae35 dfs
* f1708d0 dsfa
* e4a2839 fasdf
bfdeMacBook-Pro:lib bf$
  • 最后刪除分支初橘,
bfdeMacBook-Pro:lib bf$ git branch -d new
Deleted branch new (was b5c069c).
bfdeMacBook-Pro:lib bf$

-待續(xù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市充岛,隨后出現(xiàn)的幾起案子保檐,更是在濱河造成了極大的恐慌,老刑警劉巖崔梗,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件夜只,死亡現(xiàn)場離奇詭異,居然都是意外死亡蒜魄,警方通過查閱死者的電腦和手機(jī)扔亥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谈为,“玉大人旅挤,你說我怎么就攤上這事∩■辏” “怎么了粘茄?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長秕脓。 經(jīng)常有香客問我柒瓣,道長,這世上最難降的妖魔是什么吠架? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任嘹朗,我火速辦了婚禮,結(jié)果婚禮上诵肛,老公的妹妹穿的比我還像新娘屹培。我一直安慰自己,他們只是感情好怔檩,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布褪秀。 她就那樣靜靜地躺著,像睡著了一般薛训。 火紅的嫁衣襯著肌膚如雪媒吗。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天乙埃,我揣著相機(jī)與錄音闸英,去河邊找鬼锯岖。 笑死,一個(gè)胖子當(dāng)著我的面吹牛甫何,可吹牛的內(nèi)容都是我干的出吹。 我是一名探鬼主播,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼辙喂,長吁一口氣:“原來是場噩夢啊……” “哼捶牢!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起巍耗,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤秋麸,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后炬太,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體灸蟆,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年亲族,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了炒考。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,664評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡孽水,死狀恐怖票腰,靈堂內(nèi)的尸體忽然破棺而出城看,到底是詐尸還是另有隱情女气,我是刑警寧澤,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布测柠,位于F島的核電站炼鞠,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏轰胁。R本人自食惡果不足惜谒主,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望赃阀。 院中可真熱鬧霎肯,春花似錦、人聲如沸榛斯。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽驮俗。三九已至懂缕,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間王凑,已是汗流浹背搪柑。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工聋丝, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人工碾。 一個(gè)月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓弱睦,卻偏偏與公主長得像,于是被迫代替她去往敵國和親倚喂。 傳聞我的和親對象是個(gè)殘疾皇子每篷,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評論 2 359

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

  • 1.git的安裝 1.1 在Windows上安裝Git msysgit是Windows版的Git,從https:/...
    落魂灬閱讀 12,668評論 4 54
  • 這里沒有心靈雞湯,沒有人生箴言舱权,更沒有什么干貨分享矗晃,有的只是我個(gè)人的一些感想罷了。 最近大一的小朋友們已經(jīng)開始上課...
    暖暖的鋼炮閱讀 645評論 0 0
  • (火藥) 我第一次聽說蔡國強(qiáng)這個(gè)名字宴倍,是在有關(guān)零八年奧運(yùn)會(huì)開幕式的記錄片里张症,那個(gè)人幾乎是剃光了頭,或還有些發(fā)成茬鸵贬,...
    公介閱讀 208評論 0 0
  • 我是一個(gè)外地人,15年大學(xué)畢業(yè)后隨朋友來馬鞍山創(chuàng)業(yè)嗜浮。 在我印象里羡亩,馬鞍山只是書本中的四大鋼鐵城市之一。我的老家在安...
    禾梓2017閱讀 1,124評論 0 0