知方号

知方号

git commit回退三种姿势

git commit 回退 弄清楚三个区 工作区(working tree): 本地编辑器暂存区(index):git add操作后进入暂存区,可用git status查看本地仓库(repository):git commit 后进入本地仓库 修改commit

当我们第一次提交后,发现还有修改没有提交,通常我们想的是在add/commit一次,这样存在的问题呢就是会有一些扰乱我们的commit信息。比如我们第二次commit提交信息可能是“删除上次提交的debugger” 其实我们两次提交内容的目的都是同一个,比如修改bug,第一次提交时忘了删除我们调试时留下的debugger。然后就删除提交第二次,第二次的提示信息就很不友好。我们怎么来将两个commit合为一个呢?

git commit --amend // 把上一次的commit记录去除,修改commit信息。 git commit --amend

第一次提交,查看提交日志已经存在: 第二次add,然后提交修改 进入编辑界面,修改我们的提交信息 修改后 查看提交日志,只存在一次提交记录,信息也是显示的我们第二次提交的信息。

回退commit git reset --soft // 回退到指定commit,该commit之后的提交内容,保留工作目录,并把重置 HEAD 所带来的新的差异放进暂存区git reset --hard // 回退到指定commit,该commit之后的提交内容,工作区和暂存区的内容都被抹掉git reset 或 git reset --mixed // 不带参数,或带参数–mixed(默认参数),与git reset --soft 不同,它将会把差异放到工作区 git reset --soft

首先我们先提交两次记录,这是第一次: 第二次: 查看提交HEAD 此时工作区没有任何修改未提交 git reset --soft HEAD^之后, 工作区有修改未提交,最后一次提交的内容暂存区保存了下来 提交记录以及不在,说明仓库中没有了这次提交 我们git status 发现上次提交的内容在暂存区,想要再次提交我们再继续commit就行

git reset --hard

首先我们提交,查看提交记录 git reset --hard 1134cb6回退到版本1134cb6(git reflog 可查询HEAD) 没有了txt文件,内容被彻底的删除了。

也没有了提交记录,工作区也没有代码。这时候工作区,暂存区和仓库都是一样的回退到了指定commit

git reset HEAD || git reset --mixed

添加commit 回退,查看状态,前一次提交目前在工作区

小结 git commit --amend 好用,减少提交无用信息,可常用。git reset --soft HEAD 回退,差异存在暂存区,也好用,不轻易删除代码。git reset --hard HEAD 回退删除, 慎用,一不小心删除代码还不可逆。git reset HEAD || git reset --mixed HEAD 回退,改变的差异在工作区。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至lizi9903@foxmail.com举报,一经查实,本站将立刻删除。