git的常用操作

將更新后的文件修改提交

  • 使用git status查看哪些文件發(fā)生了修改私杜,如果需要看具體的修改內(nèi)容可以用git dif <file>
  • 使用git add <file1>, git add <file2>...將需要提交的文件添加到倉(cāng)庫(kù)屯阀,若提交所有的文件到倉(cāng)庫(kù)可使用git add.
  • 使用git commit -m " "將修改提交," "內(nèi)填寫本次提交的說(shuō)明

版本回退

  • 使用git log查看每次的提交或使用git log --pretty=oneline查看版本號(hào)和提交說(shuō)明
  • 使用git reset --hard HEAD^ 進(jìn)行回退磷杏,^ 的個(gè)數(shù)為回退的版本數(shù),后面可以直接跟數(shù)字捏卓,如:^^^^^ 和^5都表示回退5個(gè)版本
  • 也可以用git reset --hard + 版本號(hào)進(jìn)行回退

版本回退后的恢復(fù)

  • 使用git reflog查看之前的操作极祸,找到版本回退操作中顯示的之前的版本號(hào)
  • 使用git reset --hard + 需要恢復(fù)的版本號(hào)就能進(jìn)行恢復(fù)

撤銷沒有提交的修改

  • 如果文件沒有提交到暫存區(qū),本地修改了但是想回退或者是本地誤刪了文件怠晴,使用git checkout -- <file>
  • 如果文件提交到了暫存區(qū)遥金,本地又做了修改,想恢復(fù)到暫存區(qū)的狀態(tài)蒜田,也使用git checkout -- <file>
  • 如果文件提交到了暫存區(qū)稿械,想丟棄該暫存區(qū)中的修改,使用git reset HEAD <file>

文件的刪除

若本地工作區(qū)刪除了一個(gè)文件冲粤,希望版本庫(kù)中該文件也同步刪除美莫,則先git rm <file>,再git commit -m " "


創(chuàng)建一個(gè)新的分支梯捕,對(duì)項(xiàng)目修改后合并分支

  • 使用git checkout -b newbranch創(chuàng)建一個(gè)新的分支并切換到該分支上
  • 對(duì)項(xiàng)目進(jìn)行修改厢呵,并使用git add和git commit將工作區(qū)中的內(nèi)容更新到版本庫(kù)中
  • 使用git checkout master切換到master分支上,再用git merge newbranch將newbranch分支中的更新到master分支上
  • 使用git branch -d newbranch刪除分支newbranch
    建議:每當(dāng)需要寫一個(gè)新的功能時(shí)科阎,先在一個(gè)新的分支上操作述吸,最后再合并到master中

沖突解決

當(dāng)分支合并的時(shí)候可能會(huì)出現(xiàn)沖突,顯示Automatic merge failed; fix conflicts and then commit the result.使用git status可以查看出現(xiàn)沖突的文件锣笨,此時(shí)可以打開該文件蝌矛,文件中會(huì)顯示沖突的位置以及分支的不同語(yǔ)句,此時(shí)可以自行修改错英,解決完沖突后再重新git add和git commit


從未提交的分支切換到另一個(gè)分支后再回來(lái)

  • 使用git stash暫時(shí)保存當(dāng)前的工作區(qū)
  • 使用git checkout + 分支名切換到另一個(gè)分支入撒,修改后使用git add,git commit(椭岩,git merge)進(jìn)行提交(及合并)
  • 使用git checkout + 原來(lái)分支名切換回原來(lái)的分支茅逮,使用git stash list查看需要恢復(fù)的工作區(qū),然后使用git stash pop恢復(fù)該工作區(qū)并刪除stash中的內(nèi)容

在遠(yuǎn)程庫(kù)上實(shí)現(xiàn)多人開發(fā)

  • 使用git clone獲取遠(yuǎn)程庫(kù)判哥,此時(shí)只能獲取到master分支献雅。注意:需要配置SSH key后才能共同協(xié)作
  • 建立新的分支,創(chuàng)建遠(yuǎn)程庫(kù)分支對(duì)用的新分支塌计,最好取相同的名字:git checkout -b branch-name origin/branch-name
  • 注意:此時(shí)遠(yuǎn)程庫(kù)中需要有該分支挺身,否則在本地創(chuàng)建會(huì)出錯(cuò)。若此時(shí)遠(yuǎn)程庫(kù)中只有origin分支锌仅,可先用git push origin dev生成一個(gè)新的dev分支
  • 建立本地分支和遠(yuǎn)程分支的關(guān)聯(lián):git branch --set-upstream-to=origin/branch-name branch-name

本地的文件修改后章钾,推送到遠(yuǎn)程庫(kù)

  • 先用git add <file>將文件添加到暫存區(qū)
  • 再用git commit -m " "提交修改到版本庫(kù)
  • 使用git pull抓取遠(yuǎn)程最新的分支墙贱,如果有沖突,解決沖突贱傀,解決完沖突后需要重新git commit惨撇。
    注意:如果此時(shí)遠(yuǎn)程庫(kù)并沒有更新的內(nèi)容會(huì)提示Already up to date. 并不需要再解決沖突
  • 最后用git push origin branch-namer將文件推送到遠(yuǎn)程庫(kù),這里推送到的是遠(yuǎn)程庫(kù)關(guān)聯(lián)的分支

遠(yuǎn)程庫(kù)分支的合并

需要遠(yuǎn)程庫(kù)管理員的操作

  • git clone把遠(yuǎn)程的master分支克隆到本地
  • git checkout -b branch-name origin/branch-name建立本地分支
  • 建立本地分支和遠(yuǎn)程分支的關(guān)聯(lián):git branch --set-upstream-to=origin/branch-name branch-name府寒,并git pull得到最新的內(nèi)容
  • 切換為master分支魁衙,并用git merge合并分支
  • git push origin master進(jìn)行合并

在提交的時(shí)候選擇某些文件不提交

如果在使用git中某些文件需要存在但卻又不能提交時(shí),可以在git的根目錄下建立一個(gè).gitignore文件株搔,然后把需要忽略的文件名填進(jìn)去纺棺,然后把.gitignore文件提交
一般忽略的文件有:

  • 操作系統(tǒng)自動(dòng)生成的文件
  • 編譯生成的中間文件、可執(zhí)行文件
  • 帶有敏感信息的配置文件
    github上給出了一些.gitignore文件的配置:.gitignore配置
    被忽略的文件將不會(huì)被添加邪狞,若強(qiáng)行添加祷蝌,可以使用git add -f <file>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市帆卓,隨后出現(xiàn)的幾起案子巨朦,更是在濱河造成了極大的恐慌,老刑警劉巖剑令,帶你破解...
    沈念sama閱讀 217,542評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件糊啡,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡吁津,警方通過查閱死者的電腦和手機(jī)棚蓄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)碍脏,“玉大人梭依,你說(shuō)我怎么就攤上這事〉湮玻” “怎么了役拴?”我有些...
    開封第一講書人閱讀 163,912評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)钾埂。 經(jīng)常有香客問我河闰,道長(zhǎng),這世上最難降的妖魔是什么褥紫? 我笑而不...
    開封第一講書人閱讀 58,449評(píng)論 1 293
  • 正文 為了忘掉前任姜性,我火速辦了婚禮,結(jié)果婚禮上髓考,老公的妹妹穿的比我還像新娘部念。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,500評(píng)論 6 392
  • 文/花漫 我一把揭開白布印机。 她就那樣靜靜地躺著,像睡著了一般门驾。 火紅的嫁衣襯著肌膚如雪射赛。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,370評(píng)論 1 302
  • 那天奶是,我揣著相機(jī)與錄音楣责,去河邊找鬼。 笑死聂沙,一個(gè)胖子當(dāng)著我的面吹牛秆麸,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播及汉,決...
    沈念sama閱讀 40,193評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼沮趣,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了坷随?” 一聲冷哼從身側(cè)響起房铭,我...
    開封第一講書人閱讀 39,074評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎温眉,沒想到半個(gè)月后缸匪,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,505評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡类溢,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,722評(píng)論 3 335
  • 正文 我和宋清朗相戀三年凌蔬,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片闯冷。...
    茶點(diǎn)故事閱讀 39,841評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡砂心,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蛇耀,到底是詐尸還是另有隱情计贰,我是刑警寧澤,帶...
    沈念sama閱讀 35,569評(píng)論 5 345
  • 正文 年R本政府宣布蒂窒,位于F島的核電站躁倒,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏洒琢。R本人自食惡果不足惜秧秉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,168評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望衰抑。 院中可真熱鬧象迎,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至汪厨,卻和暖如春赃春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背劫乱。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工织中, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人衷戈。 一個(gè)月前我還...
    沈念sama閱讀 47,962評(píng)論 2 370
  • 正文 我出身青樓狭吼,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親殖妇。 傳聞我的和親對(duì)象是個(gè)殘疾皇子刁笙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,781評(píng)論 2 354

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

  • (預(yù)警:因?yàn)樵敿?xì),所以行文有些長(zhǎng)谦趣,新手邊看邊操作效果出乎你的預(yù)料) 一:Git是什么采盒? Git是目前世界上最先進(jìn)的...
    axiaochao閱讀 1,932評(píng)論 1 8
  • Add & Commit git init 初始化一個(gè) Git 倉(cāng)庫(kù)(repository),即把當(dāng)前所在目錄變成...
    冬絮閱讀 4,832評(píng)論 0 9
  • git 使用筆記 git原理: 文件(blob)對(duì)象蔚润,樹(tree)對(duì)象磅氨,提交(commit)對(duì)象 tree對(duì)象 ...
    神刀閱讀 3,773評(píng)論 0 10
  • 1. 下載代碼庫(kù) 2. 配置 顯示當(dāng)前git配置$ git config --listcore.symlinks=...
    yandaren閱讀 401評(píng)論 0 0
  • 早上烦租,趕著早班的火車,我們一伙四人前往廣東的丹霞山除盏。 兩個(gè)小時(shí)后叉橱,火車就到達(dá)韶關(guān)市,在火車廣場(chǎng)內(nèi)就有直達(dá)丹霞山的大...
    葉帆雪兒閱讀 1,103評(píng)論 1 4