Git自學(xué)與掉坑實(shí)錄(二)

目錄

Git自學(xué)與掉坑實(shí)錄(一)
· 創(chuàng)建版本庫
· 添加提交文件至版本庫

Git自學(xué)與掉坑實(shí)錄(二)
· 本地文件的修改與提交
· 多版本之間的切換
· 查看版本歷史
· 忽略特殊文件

Git自學(xué)與掉坑實(shí)錄(三)
· 工作區(qū)爷辙、暫存區(qū)、版本庫的概念
· 進(jìn)行到各個(gè)階段管理(添加击你、刪除符喝、恢復(fù)腻脏、修改)文件的方法

Git自學(xué)與掉坑實(shí)錄(四)
· 遠(yuǎn)程倉庫
· Github的入門說明
· 參與開源項(xiàng)目

Git自學(xué)與掉坑實(shí)錄(五)
· 管理(創(chuàng)建、合并、刪除)分支
· 解決沖突
· Fast forward模式與禁用(是否顯示合并信息)
· bug分支
· 功能分支
· 多人協(xié)作(查看信息履因、推送遠(yuǎn)程庫类咧、抓嚷濉)

Git自學(xué)與掉坑實(shí)錄(六)
· 創(chuàng)建標(biāo)簽
· 刪除標(biāo)簽(本地與遠(yuǎn)程)

Git自學(xué)與掉坑實(shí)錄(七)
· 顯示代碼顏色
· 忽略文件與強(qiáng)制添加某些忽略文件
· 搭建Git服務(wù)器

<br />
今天學(xué)習(xí)的內(nèi)容比較簡單,沒遇到什么坑痕惋。所以多寫了一些拓展的東西骗露。
</br>

五、文件的增刪改查

1.改寫wil.txt文件內(nèi)容為:
"Gold jewelry shining so bright so shine.
Strawberry champagne on ice.
Lucky for you that's what I like that's what I like."
</br>
2.輸入命令$(查看倉庫狀態(tài))git status

說明文件已被修改血巍,但還未添加萧锉、提交

3.輸入命令$(查看具體修改內(nèi)容)git diff

從紅綠兩行可以看出,我們?cè)诘谝恍刑砑恿?so shine"

</br>
4.輸入命令$(添加修改過的文件到倉庫)git add wil.txt
</br>
5.輸入命令$(查看此時(shí)的倉庫狀態(tài))git status

修改過的"wil.txt"將被提交倉庫

</br>
6.輸入命令$(提交修改過的文件到倉庫)git commit -m "add test"

</br>
7.輸入命令$(再次查看此時(shí)倉庫的狀態(tài))git status
說明此時(shí)沒有需要提交的修改述寡,工作目錄是干凈的

</br></br>

*意外情況
git status后出現(xiàn)".DS_Store"系統(tǒng)文件未被添加提交的信息


· DS_Store 是用來存儲(chǔ)這個(gè)文件夾的顯示屬性的柿隙。總言之是沒什么很大作用鲫凶,還會(huì)泄漏本地信息的這么個(gè)東西禀崖。建議刪除。

三種處理方法:
a. 刪除Git中的".DS_Store"
進(jìn)入到對(duì)應(yīng)目錄螟炫,
· 輸入命令$(刪除文件)git rm file_path

$ git rm --cached file_path#用于我們不希望這個(gè)文件被版本控制波附,但本地需要使用的刪除;
$ git rm file_path#用于我們不希望這個(gè)文件被版本控制昼钻,本地也不需要使用的刪除掸屡。

· 輸入命令$git commit -m "delete ds"
· 輸入命令$(將當(dāng)前分支推送到origin主機(jī)的對(duì)應(yīng)分支)git push origin

$ git push#用于命令用于將本地分支的更新,推送到遠(yuǎn)程主機(jī)然评。
$ git push origin#將當(dāng)前分支推送到origin主機(jī)的對(duì)應(yīng)分支仅财,如果當(dāng)前分支只有一個(gè)追蹤分支,那么主機(jī)名可以省略碗淌。

但據(jù)研發(fā)小伙伴說盏求,".DS_Store"就算刪掉了系統(tǒng)還是自動(dòng)生成抖锥,我們只能選擇忽略它……

b. 忽略Git中的".DS_Store"
在對(duì)應(yīng)的Git目錄下,創(chuàng)建一個(gè).gitignore文件碎罚,然后在該文件里配置上.DS_Store磅废。類似拉黑名單的路子。
· 輸入命令$(創(chuàng)建.gitignore)touch .gitignore荆烈;
· 輸入命令$(打開.gitignore)open .gitignore还蹲;
· 在打開的文本框內(nèi)輸入".DS_Store",換行再輸入"*/.DS_Store"耙考,保存谜喊;
· 輸入命令$(提交.gitignore)git add .gitignore&git commit -m"ignore"

$ git config --list #查看現(xiàn)有的配置

$ vim .gitignore 或簡寫 vi .gitignore#vim可以編輯文件
· 按 i 進(jìn)入編輯模式倦始;
· 編輯結(jié)束按"esc鍵"斗遏;
· 在底部彈出的輸入行,輸入":wq";
· 回車保存。

如果你已經(jīng)commit了".DS_Store"速梗,文件已經(jīng)被納入了版本管理中,再進(jìn)行忽略是無效逾一。
必須先輸入命令$(刪除緩存)git rm -r --cached file_path

另外,在教程里也有一章比較詳細(xì)地提到《忽略特殊文件》的具體辦法肮雨。

c. 假裝沒看見這行代碼…從心理上刪除……

<br />

六遵堵、版本切換

再上傳一個(gè)新版本:
對(duì)wil.txt進(jìn)行修改;

隨便加點(diǎn)什么

輸入命令$ git add&git commit -m "oh"怨规。

這樣我們一共修改了三個(gè)版本(從舊到新):版本1-"test"陌宿、版本2-"add test"、版本3-"oh"波丰。接下來我們看這三個(gè)版本之間查看切換方法:

1.概念介紹:
首先說一下"commit"的快照概念壳坪,這個(gè)概念可以輔助理解第一部分的背景介紹。廖雪峰老師把這個(gè)概念說明得很清楚掰烟,于是下面直接摘抄:

“不斷對(duì)文件進(jìn)行修改爽蝴,然后不斷提交修改到版本庫里,就好比玩RPG游戲時(shí)纫骑,每通過一關(guān)就會(huì)自動(dòng)把游戲狀態(tài)存盤蝎亚,如果某一關(guān)沒過去,你還可以選擇讀取前一關(guān)的狀態(tài)惧磺∮倍裕……Git也是一樣,每當(dāng)你覺得文件修改到一定程度的時(shí)候磨隘,就可以“保存一個(gè)快照”缤底,<b>這個(gè)快照在Git中被稱為commit</b>。一旦你把文件改亂了番捂,或者誤刪了文件个唧,還可以從最近的一個(gè)commit恢復(fù),然后繼續(xù)工作设预,而不是把幾個(gè)月的工作成果全部丟失徙歼。”

[廖雪峰-版本回退](http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013744142037508cf42e51debf49668810645e02887691000)

</br>
2.查看命令記錄:
· 輸入命令$(查看版本歷史)git log

顯示內(nèi)容包括"commit id"鳖枕、"作者&郵箱"魄梯、"文件說明"、"創(chuàng)建時(shí)間"宾符。


按時(shí)間降序排列酿秸,最新提交的日志在上

· 輸入命令$(查看版本歷史)git log --pretty=oneline

顯示內(nèi)容包括"commit id"、"文件說明"


按時(shí)間降序排列魏烫,最新提交的日志在上

前面一大串黃黃的字符就是"commit id"辣苏,每一個(gè)用戶的"commit id"都是不一樣的。

</br>
3.退回上一個(gè)版本:
· 輸入命令$(回退到上一個(gè)版本)git reset --hard HEAD^

回退到上一個(gè)版本成為當(dāng)前版本哄褒。



版本2"add test"成為當(dāng)前版本

head表示當(dāng)前版本稀蟋;head^表示上一個(gè)版本;head^^表示上上一個(gè)版本呐赡;head~100表示往上100個(gè)版本退客。

此時(shí),我們輸入命令git log --pretty=oneline后發(fā)現(xiàn)链嘀,版本3的記錄消失了井辜。

</br>
4.前往未來版本:
· 輸入命令$(回到"id"為"ba3245c"的版本)git reset --hard ba3245c

當(dāng)我們能在窗口內(nèi)直接找到該版本的"commit id"時(shí),直接輸入前幾位即可管闷。

當(dāng)在窗口內(nèi)找不到版本"commit id"時(shí)粥脚,
輸入命令$(查看該目錄所有的命令記錄)git reflog,調(diào)出需要的"id"包个。

<br /><br />

小結(jié)

$ git status#隨時(shí)查看工作區(qū)刷允、版本庫的狀態(tài)。
$ git diff #當(dāng)工作區(qū)狀態(tài)變化時(shí)碧囊,可以查看具體修改內(nèi)容树灶。add之后無法查看。
$git reset --hard HEAD^ #退回上一個(gè)版本糯而。
$ git reset --hard commit_id #可以前往id所代表版本天通。
$ git log #用于回到以前的版本。以當(dāng)前版本為終點(diǎn)熄驼,查看提交歷史命令像寒。
$ git reflog#多用于重返未來烘豹。查看所有操作過的命令記錄。
$ vim .gitignore 或簡寫 vi .gitignore #用于打開文檔诺祸;"i"進(jìn)入編輯狀態(tài)携悯,"esc鍵"退出編輯狀態(tài),輸入":wq"保存并退出筷笨。

· "commit"相當(dāng)于一個(gè)Git的快照憔鬼。
· 《忽略特殊文件》的辦法

<br /><br /><br /><br /><br /><br /><br />

主要參考:

· 廖雪峰Git教程

其他文章與資料:

· git push
· git rm與git rm --cached
· 如何刪除github上的文件
· Git 忽略一些文件不加入版本控制
· Git中全局忽略.DS_Store文件

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市胃夏,隨后出現(xiàn)的幾起案子轴或,更是在濱河造成了極大的恐慌,老刑警劉巖仰禀,帶你破解...
    沈念sama閱讀 211,265評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件照雁,死亡現(xiàn)場離奇詭異,居然都是意外死亡悼瘾,警方通過查閱死者的電腦和手機(jī)囊榜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來亥宿,“玉大人卸勺,你說我怎么就攤上這事√潭螅” “怎么了曙求?”我有些...
    開封第一講書人閱讀 156,852評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長映企。 經(jīng)常有香客問我悟狱,道長,這世上最難降的妖魔是什么堰氓? 我笑而不...
    開封第一講書人閱讀 56,408評(píng)論 1 283
  • 正文 為了忘掉前任挤渐,我火速辦了婚禮,結(jié)果婚禮上双絮,老公的妹妹穿的比我還像新娘浴麻。我一直安慰自己,他們只是感情好囤攀,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評(píng)論 5 384
  • 文/花漫 我一把揭開白布软免。 她就那樣靜靜地躺著,像睡著了一般焚挠。 火紅的嫁衣襯著肌膚如雪膏萧。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,772評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音榛泛,去河邊找鬼蝌蹂。 笑死,一個(gè)胖子當(dāng)著我的面吹牛挟鸠,可吹牛的內(nèi)容都是我干的叉信。 我是一名探鬼主播亩冬,決...
    沈念sama閱讀 38,921評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼艘希,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了硅急?” 一聲冷哼從身側(cè)響起覆享,我...
    開封第一講書人閱讀 37,688評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎营袜,沒想到半個(gè)月后撒顿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,130評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡荚板,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評(píng)論 2 325
  • 正文 我和宋清朗相戀三年凤壁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片跪另。...
    茶點(diǎn)故事閱讀 38,617評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡拧抖,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出免绿,到底是詐尸還是另有隱情唧席,我是刑警寧澤,帶...
    沈念sama閱讀 34,276評(píng)論 4 329
  • 正文 年R本政府宣布嘲驾,位于F島的核電站淌哟,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏辽故。R本人自食惡果不足惜徒仓,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望誊垢。 院中可真熱鬧掉弛,春花似錦、人聲如沸彤枢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽缴啡。三九已至壁晒,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間业栅,已是汗流浹背秒咐。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評(píng)論 1 265
  • 我被黑心中介騙來泰國打工谬晕, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人携取。 一個(gè)月前我還...
    沈念sama閱讀 46,315評(píng)論 2 360
  • 正文 我出身青樓攒钳,卻偏偏與公主長得像,于是被迫代替她去往敵國和親雷滋。 傳聞我的和親對(duì)象是個(gè)殘疾皇子不撑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評(píng)論 2 348

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

  • 目錄 Git自學(xué)與掉坑實(shí)錄(一)· 創(chuàng)建版本庫· 添加提交文件至版本庫 Git自學(xué)與掉坑實(shí)錄(二)· 本地文件的修...
    達(dá)嚕六閱讀 449評(píng)論 0 1
  • 遇到紅桃k純屬偶然,上午在一個(gè)小村子執(zhí)勤晤斩,坐在一農(nóng)戶家走廊焕檬,無所事事,聊天澳泵。忽然看到他曬著象棉球狀東西很有趣实愚,...
    寒山草堂閱讀 1,605評(píng)論 0 0