git 代码回滚

导读:合并代码时,在解决冲突的时候不小心多删除了一点代码或者是发现提交的代码有错误,导致合并后的代码无法运行,一直报错,不得不进行代码回滚操作。

基本步骤:

1cd+指定路径
2、git log

拿到你之前提交的历史,第一行的是一串40位的十六进制数字组成的commit id。
按q退出列表

3、git reset --hard HEAD(HEAD是指你需要的commit id,取前七位即可,例76f5161)

注意:这个是在你的代码未提交到远程仓库时操作的,因为reset会将你指定的HEAD后的所有commit删除,这样可能会造成新的代码丢失)

如果你的代码已经进行了远程提交,则进行下面的操作:

git checkout HEAD(HEAD是指你需要的commit id,取前七位即可,例76f5161)

4、这样代码就可以回退到指定的某次提交了(本地)

5、如果想继续将代码提交到远程,在提交过程中,有可能会出现pull失败,也无法push,提示是:

You are not currently on a branch, so I cannot use any 'branch <branchname>.merge' in your configuration file.
Please specify which remote branch you want to use on the command
line and try again (e.g. 'git pull <repository> <refspec>').
See git-pull(1) for details.

这是因为git checkout HEAD 是使HEAD头指针指向了一个具体的commit id,而不是一个分支,此时处于“分离头指针”模式,上面的提示告诉你“你不在任何分支上”,所以在添加新的提交时应创建一个新的分支

解决方法:
(1)git checkout -b temp (创建并切换temp分支)
(2)git checkout master (切换到你指定的分支上)

6、进行正常的代码远程提交操作

这样就完成了代码版本回退并正确提交的工作。

参考:http://www.cnblogs.com/houpeiyong/p/5890748.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值