亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

簡單談?wù)凣it中的回滾操作

 更新時間:2016年09月25日 16:07:55   作者:大蟒傳奇  
大家在日常開發(fā)中,經(jīng)常會遇到需要將代碼切回到之前的某個版本的情況,有可能是需要將代碼回滾,也有可能需要查看之前的某個實現(xiàn)。遇到這樣的情況,該怎么做呢?下面通過這篇文章來學習下Git中的回滾操作,有需要的可以參考借鑒。

首先介紹下場景

首先,一定要想清楚,自己想干什么。

找redis源碼作為例子,查看所在的分支git branch

 3.0
 3.2
* unstable

取前5條commit看看

git log --pretty=format:"%h - %an, %ar : %s" -5
e9d861e - antirez, 27 hours ago : Clear child data when opening the pipes.
e565632 - antirez, 27 hours ago : Child -> Parent pipe for COW info transferring.
e1eccf9 - antirez, 31 hours ago : zmalloc: Make fp var non local to fix build.
945a2f9 - antirez, 31 hours ago : zmalloc: zmalloc_get_smap_bytes_by_field() modified to work for any PID.
b13759e - antirez, 31 hours ago : redis-cli: "allocator-stats" -> "malloc-stats".

臨時切換到某個commit

有可能你并不需要回滾代碼,你只想將代碼庫暫時切換到之前的某個版本,看看那個時候的實現(xiàn),然后回來繼續(xù)寫之前沒有完成的任務(wù)。比如想看看945a2f9這個commit,執(zhí)行操作

git checkout 945a2f9
Note: checking out '945a2f9'.

You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by performing another checkout.

If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -b with the checkout command again. Example:

 git checkout -b <new-branch-name>

HEAD is now at 945a2f9... zmalloc: zmalloc_get_smap_bytes_by_field() modified to work for any PID.

再執(zhí)行git branch

* (HEAD detached at 945a2f9)
 3.0
 3.2
 unstable

可以看到處于一個臨時的分支上面,如果想以這個分支作為基礎(chǔ)開發(fā)新的功能,可以創(chuàng)建一個新的分支進行開發(fā)。

git checkout -b old-bottle 945a2f9

如果想回到之前的的分支,只要checkout回去就好了。

當然如果在切回以前的commit的之前已經(jīng)改了一些代碼,可能不會那么順利地切到之前的commit,可以

     使用reset將修改了的代碼丟棄

     stash->checkout->stash pop將修改的代碼找回來

     生成一個新的分支用于保存修改的代碼

刪除未發(fā)布的提交

如果確定要刪除某幾個commit,并且那幾個commit的代碼還沒有提交到遠程版本庫里的話。

可以這樣

git reset --hard 945a2f9

HEAD is now at 945a2f9 zmalloc: zmalloc_get_smap_bytes_by_field() modified to work for any PID.

再查看git log,就已經(jīng)看不到945a2f9之前的commit記錄了。

當然如果想保存當前沒有提交的代碼,可以和之前一樣使用stash

git stash
git reset --hard 945a2f9
git stash pop

注意:

reset --hard 一定要慎用??!

這回讓你徹底丟失本地的代碼(除非有備份過)

刪除已發(fā)布的提交

假設(shè)代碼已經(jīng)提交到遠程版本庫了,這時應(yīng)該使用revert命令,revert命令實際是提交一個新的commit來回滾之前的commit。還是以945a2f9為例,現(xiàn)在想讓代碼會滾到945a2f9的狀態(tài),那么需要revert掉之前的commit

git revert e9d861e e565632 e1eccf9

或者可以這樣做,revert掉HEAD的前三個commit

git revert HEAD~3..HEAD

之后就可以將現(xiàn)在的HEAD push到版本庫了。

如果發(fā)現(xiàn)之前revert操作錯了,可以再執(zhí)行一次revert來取消上次的revert。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,本文只是簡單講了一些我個人的一些操作實踐。希望能對大家的學習或者工作帶來一定的幫助,如果有疑問大家可以留言交流。

相關(guān)文章

  • Git如何恢復到之前版本

    Git如何恢復到之前版本

    這篇文章主要介紹了Git如何恢復到之前版本,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • firefox 擴展開發(fā)技巧

    firefox 擴展開發(fā)技巧

    firefox 擴展開發(fā)
    2009-06-06
  • Sublime中View in Browser功能不生效問題及解決

    Sublime中View in Browser功能不生效問題及解決

    這篇文章主要介紹了Sublime中View in Browser功能不生效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 分享10個程序員常用的的代碼文本編輯器

    分享10個程序員常用的的代碼文本編輯器

    通常操作系統(tǒng)和軟件開發(fā)包中都包含文本編輯器,可以用來編輯配置文件,文檔文件和源代碼,這里分享一下程序員常用的代碼編輯器,需要的朋友可以參考下
    2016-09-09
  • 詳解秒殺系統(tǒng)設(shè)計的5個要點

    詳解秒殺系統(tǒng)設(shè)計的5個要點

    這篇文章主要為大家介紹了秒殺系統(tǒng)設(shè)計的5個要點詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • git修改已commit的注釋信息實現(xiàn)

    git修改已commit的注釋信息實現(xiàn)

    這篇文章主要介紹了git修改已commit的注釋信息實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • 微信小程序設(shè)置http請求的步驟詳解

    微信小程序設(shè)置http請求的步驟詳解

    這篇文章給大家介紹了微信小程序如何進行http請求的詳細步驟,相信對大家學習微信小程序網(wǎng)絡(luò)請求會有所幫助,有需要的朋友們下面來一起看看吧。
    2016-09-09
  • Win10下為VSCode配置LaTex編輯器的方法

    Win10下為VSCode配置LaTex編輯器的方法

    這篇文章主要介紹了Win10下為VSCode配置LaTex編輯器的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • git clone 子模塊沒下載全的問題解決

    git clone 子模塊沒下載全的問題解決

    這篇文章主要介紹了git clone 子模塊沒下載全的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • vscode安裝配置clang-format插件及使用小結(jié)

    vscode安裝配置clang-format插件及使用小結(jié)

    clang-format是代碼格式化工具,本文主要介紹了vscode安裝配置clang-format,具有一定的參考價值,感興趣的可以了解一下
    2023-10-10

最新評論