<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                # git 清空緩存 # 刪除 commit 的三種方法 有時我們提交了錯誤的代碼,需要撤銷某次的 commit 記錄,而每次查資料找方法都會非常浪費時間,因此我在這篇文章總結了一下。 #### 一、刪除文件 如果需要刪除的 commit 是一個或多個文件,可以進行以下操作。 1. 被提交到倉庫的某個文件需要刪除,可以使用 `git rm` 命令: ``` <pre class="calibre13">``` <span class="token5">1.</span> git rm <span class="token"><</span>file<span class="token">></span> <span class="token6">// 從工作區和暫存區刪除某個文件</span> <span class="token5">2.</span> git commit <span class="token">-</span>m <span class="token4">""</span> <span class="token6">// 再次提交到倉庫</span> ``` ``` 2. 如果只想從暫存區刪除文件,本地工作區不做出改變,可以: ``` <pre class="calibre13">``` 1. git rm --cached <span class="token5"><span class="token5"><span class="token1"><</span>file</span><span class="token1">></span></span> ``` ``` 3. 如果在工作區不小心刪錯了某個文件,可以用 `git checkout` 將暫存區的文件覆蓋工作區的文件,從而把誤刪的文件恢復: ``` <pre class="calibre13">``` <span class="token5">1.</span> git checkout <span class="token">--</span> <span class="token"><</span>file<span class="token">></span> ``` ``` 4. 用 `git rm` 刪除文件,同時還會將這個刪除操作記錄下來; 用 `rm` 刪除文件,刪除的僅僅是本地物理文件,沒有將其從 git 的記錄中剔除。 5. `git add` 和 `git rm` 有相似的功能, 但 `git add` 僅能記錄添加、改動的動作,刪除的動作需靠 `git rm` 來完成。 #### 二、GitHub 刪除某次 commit 如果需要刪除的不只是某個文件,而是交錯的代碼,那么有以下三種方法可以刪除 commit 。 ##### 1. git reset - `git reset` :回滾到某次提交。 - `git reset --soft`:此次提交之后的修改會被退回到暫存區。 - `git reset --hard`:此次提交之后的修改不做任何保留,`git status` 查看工作區是沒有記錄的。 1. 回滾代碼 如果需要刪除的 commit 是最新的,那么可以通過 `git reset` 命令將代碼回滾到之前某次提交的狀態,但一定要將現有的代碼做好備份,否則回滾之后這些變動都會消失。具體操作如下: ``` <pre class="calibre13">``` <span class="token5">1.</span> git log <span class="token6">// 查詢要回滾的 commit_id</span> <span class="token5">2.</span> git reset <span class="token">--</span>hard commit_id <span class="token6">// HEAD 就會指向此次的提交記錄</span> <span class="token5">3.</span> git push origin HEAD <span class="token">--</span>force <span class="token6">// 強制推送到遠端</span> ``` ``` 2. 誤刪恢復 如果回滾代碼之后發現復制錯了 commit\_id,或者誤刪了某次 commit 記錄,也可以通過下方代碼恢復: ``` <pre class="calibre13">``` <span class="token5">1.</span> git relog <span class="token6">// 復制要恢復操作的前面的 hash 值</span> <span class="token5">2.</span> git reset <span class="token">--</span>hard hash <span class="token6">// 將 hash 換成要恢復的歷史記錄的 hash 值</span> ``` ``` 3. 注意:刪除中間某次提交時最好不要用 `git reset` 回退遠程庫,因為之后其他人提交代碼時用 `git pull` 也會把自己的本地倉庫回退到之前的版本,容易出現差錯進而增加不必要的工作量。 ##### 2. git rebase - `git rebase`:當兩個分支不在一條線上,需要執行 merge 操作時使用該命令。 1. 撤銷提交 如果中間的某次 commit 需要刪除,可以通過 `git rebase` 命令實現,方法如下: ``` <pre class="calibre13">``` <span class="token5">1.</span> git log <span class="token6">// 查找要刪除的前一次提交的 commit_id</span> <span class="token5">2.</span> git rebase <span class="token">-</span>i commit_id <span class="token6">// 將 commit_id 替換成復制的值</span> <span class="token5">3.</span> 進入 Vim 編輯模式,將要刪除的 commit 前面的 `pick` 改成 `drop` <span class="token5">4.</span> 保存并退出 Vim ``` ``` 這樣就完成了。 2. 解決沖突 該命令執行時極有可能出現 reabase 沖突,可以通過以下方法解決: ``` <pre class="calibre13">``` <span class="token5">1.</span> git diff <span class="token6">// 查看沖突內容</span> <span class="token5">2.</span> <span class="token6">// 手動解決沖突(沖突位置已在文件中標明)</span> <span class="token5">3.</span> git add <span class="token"><</span>file<span class="token">></span> 或 git add <span class="token">-</span>A <span class="token6">// 添加</span> <span class="token5">4.</span> git rebase <span class="token">--</span><span class="token2">continue</span> <span class="token6">// 繼續 rebase</span> <span class="token5">5.</span> <span class="token6">// 若還在 rebase 狀態,則重復 2、3、4,直至 rebase 完成出現 applying 字樣</span> <span class="token5">6.</span> git push ``` ``` ##### 3. git revert - `git revert`:放棄某次提交。 `git revert` 之前的提交仍會保留在 git log 中,而此次撤銷會做為一次新的提交。 - `git revert -m`:用于對 merge 節點的操作,-m 指定具體某個提交點。 1. 撤銷提交 要撤銷中間某次提交時,使用 `git revert` 也是一個很好的選擇: ``` <pre class="calibre13">``` <span class="token5">1.</span> git log <span class="token6">// 查找需要撤銷的 commit_id</span> <span class="token5">2.</span> git revert commit_id <span class="token6">// 撤銷這次提交</span> ``` ``` 2. 撤銷 merge 節點提交 如果這次提交是 merge 節點的話,則需要加上 `-m` 指令: ``` <pre class="calibre13">``` <span class="token5">1.</span> git revert commit_id <span class="token">-</span>m <span class="token5">1</span> <span class="token6">// 第一個提交點</span> <span class="token5">2.</span> <span class="token6">// 手動解決沖突</span> <span class="token5">3.</span> git add <span class="token">-</span>A <span class="token5">4.</span> git commit <span class="token">-</span>m <span class="token4">""</span> <span class="token5">5.</span> git revert commit_id <span class="token">-</span>m <span class="token5">2</span> <span class="token6">// 第二個提交點</span> <span class="token5">6.</span> <span class="token6">// 重復 2,3,4</span> <span class="token5">7.</span> git push ``` ``` # [清空git緩存](https://www.cnblogs.com/ldq2016/p/7921480.html) git rm -r --cached . git add . git rm --cached "文件路徑",不刪除物理文件,僅將該文件從緩存中刪除; git rm --f "文件路徑",不僅將該文件從緩存中刪除,還會將物理文件刪除(不會回收到垃圾桶)
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看