將更新后的文件修改提交
- 使用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>