git revert和git reset的区别
2015-08-13 18:51
507 查看
原文:http://blog.csdn.net/koffuxu/article/details/6731876
git revert 是撤销某次操作,此次操作之前的commit都会被保留
git reset 是撤销某次提交,但是此次之后的修改都会被退回到暂存区
具体一个例子,假设有三个commit, git st:
commit3: add test3.c
commit2: add test2.c
commit1: add test1.c
当执行git revert HEAD~1时, commit2被撤销了
git log可以看到:
commit1:add test1.c
commit3:add test3.c
git status 没有任何变化
如果换做执行git reset --soft(默认) HEAD~1后,运行git log
commit2: add test2.c
commit1: add test1.c
运行git status, 则test3.c处于暂存区,准备提交。
如果换做执行git reset --hard HEAD~1后,
显示:HEAD is now at commit2,运行git log
commit2: add test2.c
commit1: add test1.c
运行git st, 没有任何变化
另外:
git revert <commit log string>是撤消该commit,作为一个新的commit。
相关文章推荐
- 关于自定义UITableViewCell布局点击Cell消失的问题
- poj 2689 巧妙地运用素数筛选
- httpclient检查某个链接是否可用
- 4.ios-NSdictional
- Ural 1780 Gray Code 乱搞暴力
- MySQL复制表数据到新表的方法
- vim的安装和使用
- WCF—Binding
- pat 1096
- jquery记忆笔记
- 微博的开发
- 【Head First Java 读书笔记】(三)primitive主数据类型和引用
- jquery记忆笔记
- iOS 开发小技巧
- 使用Sandcastle生成CHM帮助文档
- IDEA下使用Jetty进行Debug模式调试
- Gym 100625H 多边形面积-计算几何
- java dom解析xml
- CMD方式修改MySQL的root用户密码
- 图片下载的作业