农妇山泉一亩田 发表于 2025-4-17 02:27:15

git reset详解

一、git reset 的核心作用

用于 移动当前分支的 HEAD 指针 到指定的提交,并可选择是否修改工作区和暂存区。
⚠️ 注意:若提交已被推送到远程仓库,强制重置(--hard)后需谨慎操纵,制止影响协作。
二、三种模式对比

模式下令示例影响范围适用场景--softgit reset --soft HEAD~1仅移动 HEAD,保留修改在 暂存区修改提交信息或合并提交--mixedgit reset HEAD~1移动 HEAD,保留修改在 工作区撤销提交但保留代码修改(默认模式)--hardgit reset --hard HEAD~1移动 HEAD,丢弃所有修改彻底回退到汗青版本(慎用!) 三、详细使用场景

1. 回退到指定提交

 
# 查看提交历史,获取目标 commit-hash
git log --oneline

# 回退到指定提交(默认 --mixed)
git reset abc1234 2. 撤销最近一次提交但保留代码

git reset HEAD~1          # 或 git reset --mixed HEAD~1  


[*] 修改会保留在工作目录,可重新编辑后提交。
3. 修改最后一次提交(不产生新提交)

git add <漏掉的文件>      # 添加遗漏的修改
git reset --soft HEAD~1   # 撤销提交但保留修改到暂存区
git commit -m "新描述"   # 重新提交 4. 彻底丢弃本地所有修改

git reset --hard HEAD   # 丢弃所有未提交的修改(包括工作区和暂存区) 四、关键参数详解

1. 指定回退步数



[*] HEAD~1:回退 1 个提交
[*] HEAD~3:回退 3 个提交
2. 回退到远程仓库状态

git reset --hard origin/main# 强制与远程 main 分支一致 3. 回退单个文件

git reset HEAD~1 -- path/to/file# 仅回退该文件到指定版本
git checkout HEAD~1 -- path/to/file# 替代方案(保留提交历史) 五、与 git revert 的区别

下令特点适用场景git reset删除提交汗青,改变 HEAD本地未推送的提交回退git revert生成新提交来撤销旧提交已推送提交的撤销 示例:


[*] 撤销已推送的提交:
git revert abc123# 生成一个反向提交
git push          # 安全推送
 
六、风险与注意事项


[*] --hard 会永世丢弃修改:

[*] 确保无需保留代码再使用,或提前 git stash 备份。

[*] 强制推送需团队协商:
git reset --hard HEAD~3
git push -f origin main# 强制覆盖远程(谨慎!)  
3.规复误操纵:


[*] 通过 git reflog 找回丢失的提交哈希
 
七、可视化示例

初始状态

A <- B <- C (HEAD -> main) 执行 git reset --soft B

A <- B (HEAD -> main)
# C 的修改保留在暂存区 执行 git reset --mixed B
A <- B (HEAD -> main)
# C 的修改保留在工作区 执行 git reset --hard B
A <- B (HEAD -> main)
# C 的修改被彻底丢弃 八、总结下令速查

需求下令撤销提交但保留代码git reset HEAD~1修改最后一次提交git reset --soft HEAD~1彻底回退到汗青版本git reset --hard abc123撤销对单个文件的提交git reset HEAD~1 -- file.txt  


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: git reset详解