git恢复commit过的代码

本文详细介绍了如何通过gitfsck--lost-found找回丢失的ssh记录,包括gitshowcommitId查看commit内容,以及git merge操作。涵盖未git add、未commit、已commit未push和已push的情况,并介绍git-reflog的实用技巧。还涉及git reset和git checkout的回滚策略,以及git stash的相关恢复方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、查看丢失记录

git fsck --lost-found

找回丢失的satsh记录,只有commit 才能够被恢复。

也可以执行git log命令找到commit id。

二、查看具体内容

git show commitId

三、找到commitId 进行git merge commitId 即可

四、git回滚文件场景总结

1、修改完还未git add:使用 git checkout 回滚

使用暂存区的文件覆盖工作区,所以执行完 git add . 之后,再执行该命令是无效的。 git checkout . 和 git add . 是一对反义词。

2、git add提交还未commit

使用 git add 提交到暂存区,还未 commit 之前,使用 git reset 和 git checkout 回滚:

git reset  # 先用 Head 指针覆盖当前的暂存区内容
git checkout . # 再用暂存区内容覆盖工作区内容

或者使用直接使用 head (在git中,用HEAD表示当前版本)覆盖当前暂存区和工作区。

# 恢复当前版本,删除工作区和缓存区的修改

git reset --hard

3、已经git commit还未git push

使用 git reset 回滚:覆盖本地仓库、暂存区和工作区

git reset --hard <last_commit_id>

4、已经git push

git reset --hard <commit_id>

强制提交当前版本号:git push origin <远端分支名称> --force

五、Git:git-reflog的用法

参考:Git:git-reflog的用法总结_IT老兵驿站的博客-优快云博客_git reflog

git-reflog()是用来恢复本地错误操作很重要的一个命令,示例如下:

 比如我们想恢复到某个版本,如下:

3aba2df HEAD@{4}: commit: tor-92 [Story] 性能测试服务化,服务号触发时支持locust压测地址替换

执行如下命令即可:

git reset --hard HEAD@{4}

参考:

git stash clear后,如何找回并恢复代码

commit的内容 还原git_工作中必备的git技能(上)_weixin_39673037的博客-优快云博客

【git撤销操作】git reset详解_Chx.zhang的博客-优快云博客_git 撤销reset

### 如何从指定的 Git Commit 拉取代码 为了从特定的 Git 提交中拉取代码,可以通过以下方法实现: #### 方法一:使用 `checkout` 命令切换到指定提交 当需要查看或操作某次历史提交的状态时,可以直接通过该提交的哈希值来检出此版本。 ```bash git checkout <commit_id> ``` 这条命令会将当前的工作目录重置为给定 `<commit_id>` 所指向的那个快照。需要注意的是,在这种模式下,HEAD 将处于分离状态[^3]。 #### 方法二:创建临时分支并基于指定提交初始化 为了避免在 HEAD 处于游离状态下工作带来的不便,可以在指定提交的基础上建立一个新的分支来进行后续开发活动。 ```bash git checkout -b temp-branch <commit_id> ``` 这样不仅能够保持原有分支结构不变,还可以方便地在这个新分支上继续进行更改和测试[^4]。 #### 方法三:仅获取单个文件的历史版本 如果只需要恢复某些具体文件在过去某一时刻的内容,则不必整个项目回滚至那个时间点;而是利用如下方式单独提取所需资源。 ```bash git checkout <commit_id> -- path/to/file.txt ``` 上述指令允许用户精确控制哪些部分应该被还原成旧版样子,而不会影响其他未指明路径下的任何东西[^5]。 对于希望保留现有改动的同时同步远端更新的情况,建议先保存本地变更再执行合并操作: ```bash git stash # 保存当前修改 git pull origin dev # 获取最新远程代码 git stash pop # 恢复之前暂存的变化以便进一步处理冲突等问题 ``` 最后提醒一点,完成以上任一步骤之后记得及时推送自己的成果上去以免造成不必要的麻烦[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

rs勿忘初心

你的鼓励将是我持续创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值