【超详细】Git 所有常用命令 + 提交规范全指南(建议收藏!)
liuian 2025-09-23 23:33 59 浏览
Git 命令大全
初始化类
命令 | 作用 |
git init | 初始化一个本地 Git 仓库(当前目录会出现 .git 文件夹) |
git clone <仓库地址> | 克隆远程仓库到本地,一般用来拉项目 |
提交代码类
命令 | 作用 |
git status | 查看当前状态(有哪些文件改了,有哪些还没提交) |
git add <文件> | 把文件添加到暂存区(准备提交) |
git add . | 把所有改动的文件加入暂存区 |
git commit -m "提交信息" | 提交代码(将暂存区的内容提交到本地仓库) |
git commit -am "提交信息" | 跳过 add,直接提交已跟踪文件的修改 |
git log | 查看提交记录 |
git diff | 查看未暂存的代码改动 |
git diff --cached | 查看已暂存(add 过的)但还没 commit 的改动 |
远程仓库类
命令 | 作用 |
git remote -v | 查看远程仓库信息 |
git remote add origin <地址> | 关联远程仓库 |
git push -u origin master | 第一次推送,关联本地和远程分支 |
git push | 推送代码到远程 |
git pull | 拉取远程代码并合并 |
git fetch | 拉取远程代码但不自动合并,需要自己手动 merge |
分支管理类
命令 | 作用 |
git branch | 查看所有分支 |
git branch <名字> | 创建新分支 |
git checkout <分支名> | 切换分支 |
git checkout -b <名字> | 新建并切换分支 |
git merge <分支名> | 把某个分支合并到当前分支 |
git branch -d <名字> | 删除本地分支 |
git push origin --delete <名字> | 删除远程分支 |
回退与撤销类
命令 | 作用 |
git reset --hard <版本号> | 回退到某个提交(彻底还原) |
git reset --soft <版本号> | 回退但保留改动在暂存区 |
git reset HEAD <文件> | 撤销某个 git add |
git checkout -- <文件> | 丢弃当前文件的修改 |
git revert <commit id> | 反做一个 commit,保留历史记录 |
标签类
命令 | 作用 |
git tag | 查看所有标签 |
git tag <名字> | 创建标签 |
git tag -d <名字> | 删除标签 |
git push origin <名字> | 推送标签到远程 |
git push origin --tags | 推送所有标签 |
清理类
命令 | 作用 |
git clean -f | 删除未被追踪的文件 |
git stash | 临时保存当前工作区修改 |
git stash pop | 恢复之前保存的修改 |
git gc | 清理 Git 仓库空间 |
Git 合并策略深入讲解
分支的合并策略、变基、快进合并、压缩提交(squash)等。这些不但影响提交记录的整洁度,也会直接关系到协作开发时的效率和出错率。
合并(git merge)
记录历史轨迹,不改原提交!这是最安全也最常用的方式,适合团队协作。
git checkout main
git merge feature/login- 结果:创建一个新的“合并提交”(merge commit)
- 保留所有历史轨迹,看得清楚哪个分支做了哪些改动
- 可能会出现冲突,你得手动处理
变基(git rebase)
把一个分支“平移”到另一个分支上
git checkout feature/login
git rebase main- 把 feature/login 分支的提交历史移到 main 的最后一个提交之后
- 不会产生 merge commit,历史会“更干净”
- 本质上是改写历史,所以不要对别人已推送过的分支 rebase
快进合并(Fast-forward)
直接把 main 指针推进去! 当你当前分支落后于 feature 分支时,Git 不需要创建合并提交,而是直接“快进”。
git merge feature --ff-only- 不会产生额外的 merge commit
- 条件:main 分支 没有新的提交
压缩提交(git merge --squash)
git checkout main
git merge --squash feature/login
git commit -m "feat(login): 新增登录功能"- 把 feature 分支的一堆提交压成一个提交
- 不会保留 feature 分支的原始历史
- 类似“整活之后只展示最终成果”
交互式压缩提交
git rebase -i HEAD~5会弹出编辑器,让你可以选择每个提交:
pick 123abc 登录接口
pick 456def 修复登录跳转
pick 789ghi 删除 console.log
# 改成这样
pick 123abc 登录接口
squash 456def 修复登录跳转
squash 789ghi 删除 console.log这样这三个提交就会压缩成一个,更干净、好看。
Git 提交规范(写出专业的 commit message)
很多时候,团队协作最怕看到这种提交记录:
fix bug
update
123
aaaaaaa这不仅不利于版本回滚,也没法看出每次提交干了啥。
推荐的格式
<type>: <描述>feat: 新增/修改功能 (feature)。
fix: 修補 bug (bug fix)。
docs: 文件 (documentation)。
style: 格式 (不影響程式碼運行的變動 white-space, formatting, missing semi colons, etc)。
refactor: 重構 (既不是新增功能,也不是修補 bug 的程式碼變動)。
perf: 改善效能 (A code change that improves performance)。
test: 增加測試 (when adding missing tests)。
chore: 建構程序或輔助工具的變動 (maintain)。
revert: 撤銷回覆先前的 commit 例如:revert: type(scope): subject (回覆版本:xxxx)。
version: 更新版本信息。长提交
feat: 新增用户头像上传功能
- 支持头像上传预览
- 增加接口字段校验
- 优化上传组件交互体验总结
Git 本身不复杂,但想用好、用得专业,还是需要一些体系感。记住下面几个关键点
1. 搞清楚 add、commit、push 的区别
2. 分支合并时要多用 pull --rebase 避免历史太乱
3. 用语义化的提交规范,养成好习惯
4. 不会的就看 git log --oneline --graph,一切尽在图中
相关推荐
- 小米路由器管理员初始密码(miwifi小米路由器管理员初始密码)
-
小米路由器管理员密码初始是123456。1、小米路由器的管理员初始密码是admin。2、如果输入admin路由器没有反应,说明密码错误,可以查看路由器背面的管理员登录密码,登录后可以自行修改设置账户名...
- 路由器组网具体连接方法(路由器组网教程)
-
举例:你正在用一个TP-LINK的无线路由器上网,信号不是太好,你想在下边再连一个无线路由器的话,就得在第二个路由器上设置了,先不管第一个路由器,设置步骤:把第二个无线路由器连接到电脑上(只是路...
- 雨林木风win7纯净版gho(雨林木风win7官网)
-
雨林木风WIN7光盘重装系统的步骤是将光盘放入光驱内,设置光驱为第一启动盘,打开电脑后进入光盘引导,最后将系统文件镜像到系统盘上1.你下载的雨林木风GHOSTXPSP3纯净版Y8.0是一个克隆光...
- 电脑一直正在重新启动怎么解决
-
1、电脑误删除或者是破坏了系统文件。那么需要重新安装系统。2、可能是安装的软件或者是插件跟系统兼容性冲突导致的。可以强制关机3次,然后重新启动电脑会出现恢复界面——选择安全模式——然后电脑会重新启...
-
- 如何下载ps软件免费版(ps如何下载免费版本)
-
1.在搜索引擎中输入adobe并点击搜索。2.点击adobe官网。3.点击支持并点击下载与安装。4.点击开始免费试用并点击下载。5.打开文件夹并点击打开进行安装即可。6.根据以上步骤即可下载安装ps。AdobePhotoshopCS6号...
-
2026-01-14 05:37 liuian
- 怎么判断该换硅脂了(cpu硅脂干了影响真的很大吗)
-
方法步骤如下第一,从系统软件的运行上来看,如果在运行某些大型软件,容易导致显卡发热的程序时,出现画面掉帧,或卡顿,甚至是画面卡死等情况,这大多是因为显卡散热出现问题,导致显卡自动降频,以降低功耗来减少...
- 壁纸图片2025最新款(电脑桌面壁纸图片2025最新款)
-
要更换2023最新款壁纸图片,可以按照以下步骤操作:首先,找到您想要更换的壁纸图片并下载到您的设备上。其次,进入您的设备设置,找到“壁纸”或“桌面壁纸”选项,并点击进入。然后,选择“更换壁纸”并在相册...
- 清理垃圾的神器(清理垃圾的神器是什么)
-
1、《腾讯手机管家》这款可以帮助用户进行强力的清理,加速告别空间卡顿,缓慢延迟的问题的软件当中,用户可以随时随地登录软件进行自动清理和自动清理,自动清理包括图片,视频,语音文件在内的各种换成文件,为手...
- 苹果笔记本怎样重装系统(苹果笔记本怎样重装系统还原)
-
苹果笔记本电脑系统可以通过以下步骤进行重装:1.备份数据:在开始重装前,需要备份你的重要数据。你可以将数据存储到外部硬盘、云存储或其他可靠的设备中。2.下载安装器:从AppStore中下载macOS...
- 手机wifi打不开怎么办
-
手机wifi打不开的原因,可能集中在该手机出现了手机文件丢失、手机版本不稳定、手机文件出错以及手机wifi模块摔坏等故障造成的。手机wifi打不开修复教程1.wcnss_qcom_cfg文件丢失导...
- bios恢复出厂设置后无法开机
-
可通过进入BIOS界面设置bios恢复出厂设置的方法解决,步骤如下:1、通过按Delete或数字键盘中的Del键进入BIOS。2、按箭头键输入并将光标移动到“加载设置默认值”项,然后按enter确认。...
- 电脑硬盘打不开怎么办(电脑硬盘打不开怎么办)
-
电脑硬盘坏了是不能开机的。硬盘坏道的修复方法:1、逻辑坏道的修复对于逻辑坏道,Windows自带的“磁盘扫描程序(Scandisk)”就是最简便常用的解决手段。如果硬盘出现了坏道,我们可在Window...
- linux系统备份与还原工具(linux系统备份与还原工具在哪)
-
用GHOST对LINUX系统做备份1:要求将安装了LINUX系统的硬盘(原盘)整盘刻至另一硬盘(目标盘)。2:所需工具:DOS系统引导盘,GHOST2003(版本低的对文件格式不能很好的支持),原盘(...
- pdf怎么转换成xml格式(如何将pdf格式转换成xml格式)
-
将PDF转换为XML需要使用专业的PDF转换工具。以下是一些常用的PDF转XML工具:1.AdobeAcrobatDC:AdobeAcrobatDC是一款功能强大的PDF编辑软件,其中包括P...
- windows7iso文件(iso文件 win7)
-
利用winrar可以直接打开iso文件,如果双击不能直接打开需要设置winrar,步骤如下:1、启动winrar,点击选项菜单设置命令;2、点击综合选项卡,点击全部选择,点击确定即可。具体操作方法步骤...
- 一周热门
-
-
飞牛OS入门安装遇到问题,如何解决?
-
如何在 iPhone 和 Android 上恢复已删除的抖音消息
-
Boost高性能并发无锁队列指南:boost::lockfree::queue
-
大模型手册: 保姆级用CherryStudio知识库
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
威联通NAS安装阿里云盘WebDAV服务并添加到Infuse
-
Trae IDE 如何与 GitHub 无缝对接?
-
idea插件之maven search(工欲善其事,必先利其器)
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
