A. Git怎麼還原上一個版本
第一步: git log 查看之前的commit的id,找到想要還原的版本
第二步: git reset --hard 還原到之前的某個版本
第三步: git push -f origin master 強制回push到遠程
前兩步在eclipse中也可答操作:
team --> show in hostory
找到想還原的版本
然後再強制push (git push -f origin master)
B. 在eclipse裡面使用SVN,怎麼實現版本回滾
工具:
eclipse
svn
方法:
點擊window--show view--other
C. 63.Git Reset 詳解版本回滾的三種模式
意思就是可以讓HEAD這個指針指向其他版本。說白了就是通過此命令在版本之間進行穿梭。
它有三種模式,soft,mixed,hard,具體的使用方法下面這張圖,展示的很全面了。
這三個模式理解了,對於使用這個命令很有幫助。在理解這三個模悔敬簡式之前,需要略微知道一點Git的基本流程。正如上圖,Git會有三個區域:
Working Tree 當前的工作區域
Index/Stage 暫存區域,和git stash命令暫存的地方不一樣。使用git add xx,就可以將xx添加近Stage裡面
Repository 提交的歷史,即使用git commit提交後的結果
首先, Git 必須知道當前版本是哪個版本,在 Git 中,用 HEAD 表示當前版本,上一個版本就是 HEAD^ ,上上一個版本就是 HEAD^^ ,以此類推,當然往上100個版本寫100個 ^ 比較容易數不過來,所以寫成 HEAD~100 。
--hard 會在重置 HEAD 和branch的同時,重置緩存區和工作目錄里的內容。當你在 reset 後面加了 --hard 參數時,你的緩存區和工作目錄里的內容會被完全重置為和HEAD的新位置相同的內容。換句話說,就是你的沒稿芹有commit的修改會被全部擦掉。
回退到上一版本:
回退到指定版本號(以1a2b3c為例)的版本:
reset --hard:重置stage區和工作目錄:
--soft 則會保留工作目錄的內容,並把因為重置 HEAD 所帶來的新的文件差異放進暫存區。
什麼是「重置 HEAD 所帶來的新的差異」?就是這里:
由於 HEAD 從 4 移動到了 3,而且在 reset 的過程中工作目錄和暫存區的內容沒有被清理掉,所以 4 中的改動在 reset 後就也成了工作目錄新增的「工作目錄和 HEAD 的差異」。這就是上面一段中所說的「重置 HEAD 所帶來的差異」。
這就是--soft 和 --hard 的區別:--hard 會清空工作目錄和暫碧褲存區的改動,*而 --soft則會保留工作目錄的內容,並把因為保留工作目錄內容所帶來的新的文件差異放進暫存區。
git reset 如果不加參數,那麼默認使用 --mixed 參數。此時表示要:保留工作目錄,並清空暫存區。也就是說,工作目錄的修改、暫存區的內容以及由 reset 所導致的新的文件差異,都會被放進工作目錄。簡而言之,就是「把所有差異都混合(mixed)放在工作目錄中」。
首先, Git 必須知道當前版本是哪個版本,在 Git 中,用 HEAD 表示當前版本,上一個版本就是 HEAD^ ,上上一個版本就是 HEAD^^ ,以此類推,當然往上100個版本寫100個 ^ 比較容易數不過來,所以寫成 HEAD~100 。
回退到上一版本:
回退到指定版本號(以1a2b3c為例)的版本:
--hard 會清空工作目錄和暫存區的改動,
--soft則會保留工作目錄的內容,並把因為保留工作目錄內容所帶來的新的文件差異放進暫存區。
--mixed 參數。git reset 如果不加參數,那麼默認使用 --mixed 參數。此時表示要:保留工作目錄,並清空暫存區。
HEAD指向的版本就是當前版本,因此,Git允許我們在版本的歷史之間穿梭,使用命令
git reset --hard commit_id
穿梭前,用 git log 可以查看提交歷史,以便確定要回退到哪個版本。
要重返未來,用 git reflog 查看命令歷史,以便確定要回到未來的哪個版本。
D. 在eclipse裡面使用SVN,怎麼實現版本回滾
在eclipse裡面使用SVN實現版本回滾的方法:
一、如果有本地修改,需提交蔽旅到遠程svn伺服器或撤銷修改;
二、更新本地代碼,保持和遠程代碼一致,如下圖:
五、svn提交修改,生成一個回滾後的最新版本。