目录

Git常用命令全面分类总结

Git常用命令全面分类总结

Git常用命令全面分类总结

以下是Git常用命令的全面分类总结,以及 git reset --hard 的详细解析,结合结构化的说明和示例,便于我们理解和记忆:


一、Git核心命令分类速查表

1. 仓库初始化与克隆
命令作用示例
git init初始化本地仓库git init
git clone克隆远程仓库git clone https://github.com/user/repo.git
2. 工作区与暂存区操作
命令作用示例
git add添加文件到暂存区git add file.txt (单文件) git add . (全部)
git restore撤销工作区修改git restore file.txt
git reset撤销暂存区提交git reset HEAD~1 (回退到前一次提交)
3. 提交与日志
命令作用示例
git commit提交到本地仓库git commit -m "提交说明"
git log查看提交历史git log --oneline (简洁版)
git diff比较差异git diff HEAD~1 (对比前一次提交)
4. 分支管理
命令作用示例
git branch查看/创建分支git branch dev (创建dev分支)
git checkout切换分支git checkout dev
git merge合并分支git merge dev (将dev合并到当前分支)
git rebase变基操作git rebase main (将当前分支变基到main)
5. 远程仓库交互
命令作用示例
git push推送本地提交到远程git push origin main
git pull拉取远程更新并合并git pull origin dev
git fetch仅拉取远程更新git fetch origin
6. 撤销与恢复
命令作用示例
git revert生成新提交以撤销历史提交git revert 提交ID
git reset回退到指定提交(危险操作)git reset --hard HEAD~1
git stash暂存未提交的修改git stash (保存) git stash pop (恢复)

二、 git reset --hard 深度解析

1. 作用
  • 彻底回退 :将当前分支的 HEAD暂存区工作区 全部重置到指定提交状态。
  • 数据丢失风险 :未提交的修改和未推送的提交将被永久删除!
2. 参数对比
参数影响范围适用场景
--soft仅移动 HEAD 指针修改提交历史,保留工作区和暂存区
--mixed (默认)移动 HEAD ,重置暂存区撤销 git add 操作,保留工作区修改
--hard移动 HEAD ,重置暂存区和工作区彻底丢弃所有未提交的修改
3. 使用示例
# 回退到前一次提交(丢弃最新提交)
git reset --hard HEAD~1

# 回退到特定提交(根据提交ID)
git reset --hard a1b2c3d

# 强制同步远程仓库(本地与远程一致)
git reset --hard origin/main
4. 注意事项
  • 备份 :使用前确保工作区和暂存区的重要修改已备份。
  • 协作影响 :若已推送提交到远程,强制推送( git push -f )会破坏他人代码,需谨慎!
5. 类比记忆
  • 软重置( --soft :像取消邮寄包裹,但包裹还在手中。
  • 混合重置( --mixed :包裹拆开,物品放回工作台。
  • 硬重置( --hard :直接丢弃包裹和所有未打包的物品。

三、常用场景速查

  1. 误提交后撤销 :使用 git reset --hard HEAD~1 丢弃最后一次提交。
  2. 恢复文件到最新版本git restore file.txtgit checkout -- file.txt
  3. 清理未跟踪文件git clean -df (删除未跟踪的文件和目录)。

四、总结

  • Git命令分类记忆 :按操作目标(仓库、提交、分支、远程)分类,避免混淆。
  • git reset --hard 慎用 :它是“后悔药”中的核武器,威力大但破坏性强。
  • 安全操作习惯 :频繁提交、多用分支、重要修改前备份。