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. 使用示例
bash 复制代码
# 回退到前一次提交(丢弃最新提交)
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 慎用:它是"后悔药"中的核武器,威力大但破坏性强。
  • 安全操作习惯:频繁提交、多用分支、重要修改前备份。
相关推荐
淡淡的id1 小时前
git的功能分支的base分支错了怎么重新提交
git
Ever_Zhang3 小时前
Git 大文件使用 Git-LFS 管理,推送失败
git·git lfs·gitattributes·git 推送大文件
-曾牛5 小时前
Git Flow
大数据·git·学习·elasticsearch·个人开发
Zfox_5 小时前
Git 进阶之路:高效协作之分支管理
大数据·linux·运维·c++·git·elasticsearch
小生不才yz6 小时前
23. git reset
git
码农小站7 小时前
开发手记 | IDEA代码Push后回退
git
兔六哥7 小时前
当更改新的 git 仓库地址时,不要着急执行 clone 应该先运行这个
git
weixin-a1530030831612 小时前
git常用命令
git
前端小干将14 小时前
开发过程中,git常用命令
git
西柚啊15 小时前
Git常用命令总结
前端·git