news 2026/4/16 16:23:41

Git 常用命令与使用方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Git 常用命令与使用方法

一、Git 基本概念

1. 三个核心区域

  • 工作区(Working Tree)
    本地正在编辑、修改代码的目录

  • 暂存区(Index / Stage)
    通过git add选择、准备提交的改动

  • 本地仓库(Repository)
    已通过git commit保存的历史版本

Git 的本质:在这三个区域之间移动和管理代码变更。


二、最基础且最常用的命令

1. 查看仓库状态(最常用)

gitstatus

用途:

  • 查看哪些文件被修改
  • 哪些文件已加入暂存区
  • 哪些文件是未跟踪文件

2. 查看提交历史

gitloggitlog --oneline --graph --decorate

用途:

  • 查看提交记录
  • 分析历史版本
  • 配合 Git Graph 使用

3. 查看代码差异

gitdiff# 工作区 vs 暂存区gitdiff--staged# 暂存区 vs 最近一次提交gitdifffile.cpp# 指定文件差异

用途:

  • 在提交前确认具体改了什么

三、暂存区操作(add / reset)

1. 添加文件到暂存区

gitaddfile.cppgitadddir/gitadd.
推荐用法(精细控制):
gitadd-p

作用:

  • 按代码块逐段选择是否加入暂存区
  • 非常适合团队协作

2. 取消 add(撤销暂存)

gitresetgitreset file.cpp

说明:

  • 不删除代码
  • 只是把文件从暂存区移回工作区

四、提交代码(commit)

1. 普通提交

gitcommit -m"commit message"

2. 提交全部已修改文件(不推荐常用)

gitcommit -a -m"message"

建议:commit 信息要清晰描述做了什么,便于团队理解。


五、远程仓库操作(Gitee / GitHub)

1. 查看远程仓库

gitremote -v

2. 添加远程仓库

gitremoteaddorigin https://gitee.com/xxx/project.git

3. 推送代码

gitpushgitpush -u origin mastergitpush -u origin main

说明:

  • -u:建立本地分支与远程分支的关联

4. 拉取远程代码

gitpullgitpull --rebase

推荐使用:

  • git pull --rebase(提交历史更干净)

六、分支管理(团队协作必备)

1. 查看分支

gitbranchgitbranch -a

2. 创建并切换分支

gitcheckout -b feature_xgitswitch -c feature_x

3. 切换分支

gitcheckout mastergitswitch master

4. 删除分支

gitbranch -d feature_x

七、冲突处理与 rebase

1. 使用 rebase 拉取远程代码

gitpull --rebase

2. 解决冲突流程

gitadd.gitrebase --continue

3. 放弃 rebase

gitrebase --abort

八、临时保存修改(stash)

1. 保存当前修改

gitstash

2. 恢复修改

gitstash pop

3. 查看 stash 列表

gitstash list

适用场景:

  • 拉代码前本地还有未完成修改

九、撤销与回退(慎用)

1. 丢弃工作区修改

gitrestore file.cppgitrestore.

2. 回退到某个提交(危险)

gitreset --hard commit_id

十、问题定位相关命令

1. 查看某文件的提交历史

gitlog file.cpp

2. 查看每一行是谁改的

gitblame file.cpp

十一、推荐的日常标准工作流(总结)

gitstatusgitadd-pgitcommit -m"清晰的提交说明"gitpull --rebasegitpush

十二、学习总结要点

  1. 任何操作前,先看git status
  2. 尽量少用git add .,多用git add -p
  3. 团队协作优先使用pull --rebase
  4. 不确定时,不要使用push -f

十三、真实踩坑记录(实战经验总结)


踩坑 1:git push提示 non-fast-forward 被拒绝

现象 / 报错:

! [rejected] master -> master (non-fast-forward) error: 无法推送一些引用到远程仓库

原因:

  • 远程分支已有新提交(如 README、他人提交)
  • 本地分支落后于远程分支

错误做法:

gitpush -f# ⚠ 覆盖远程,团队协作中非常危险

正确做法(推荐):

gitpull --rebase origin mastergitpush

踩坑 2:git pull --rebase提示有未暂存修改

报错信息:

error: 不能变基式拉取:您有未暂存的变更

原因:

  • 工作区有修改但未提交
  • Git 不允许在脏工作区执行 rebase

正确解决方案(最安全):

gitstashgitpull --rebasegitstash pop

踩坑 3:执行了git add .,但想只提交部分文件

问题:

  • 不小心把所有文件 add 进暂存区

解决方法:

gitreset# 取消全部暂存gitaddfile1.cpp# 重新选择需要提交的文件

经验总结:

  • 团队开发中,优先使用git add -p

踩坑 4:文件内容明明不一样,但git diff file.cpp无输出

常见原因:

  1. 文件其实没有被 Git 跟踪
  2. 对比的不是当前分支的内容
  3. VS Code 中的文件未保存到磁盘

排查命令:

gitls-files|grepfile.cppgitdiff--name-statusgitstatus

踩坑 5:git add 文件.*没有效果,暂存区看不到文件

原因:

  • 文件没有任何修改
  • Git 只会暂存“发生变化”的文件

验证方式:

gitdiff文件名

结论:

没有 diff,就没有 add,也不会产生 commit。


踩坑 6:VS Code Git Graph 打不开(Webview / ServiceWorker 报错)

典型报错:

Could not register service worker: InvalidStateError

原因:

  • VS Code Webview Service Worker 在部分 Linux 环境异常

解决方式(settings.json):

"webview.experimental.enableServiceWorkers":false

然后重启 VS Code。


踩坑 7:stash 之后忘了恢复代码

现象:

  • git stash后感觉代码“丢了”

解决:

gitstash listgitstash pop

经验:

stash 不会丢代码,只是临时存放。


踩坑 8:误用git reset --hard

后果:

  • 工作区和暂存区修改全部丢失

原则:

  • 非必要不使用--hard
  • 不熟悉 commit_id 时禁止使用

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/9 5:54:00

Dify工作流集成Anything-LLM实现企业级智能任务自动化

Dify 与 Anything-LLM:构建企业级智能任务自动化的新范式 在一家中型科技公司的人力资源部门,HR专员小李每天要重复回答几十遍“年假怎么算”“产假包含节假日吗”这样的问题。这些咨询本身不难,但累积起来占据了她近半的工作时间。而与此同时…

作者头像 李华
网站建设 2026/4/16 16:09:14

云边协同:云服务器在边缘计算场景中的价值重构与实践探索

随着智慧城市、工业物联网、车联网等场景的兴起,数据处理对实时性的要求愈发严苛。传统集中式云服务器架构下,数据从终端传输至云端处理的路径过长,难以满足毫秒级响应需求。边缘计算的出现打破了这一困境,而云服务器作为核心枢纽…

作者头像 李华
网站建设 2026/4/16 14:23:33

LobeChat能否优化SEO标题?内容创作者必备

LobeChat:内容创作者的智能中枢,如何用它优化SEO标题? 在内容为王的时代,写一篇好文章只是第一步,能否被搜索引擎“看见”,往往决定了它的命运。一个高点击率的SEO标题,可能让一篇平平无奇的文章…

作者头像 李华
网站建设 2026/4/16 16:11:16

PowerDMIS 自动公差 范围设置区

自动公差 是PowerDMIS 中一项强大的效率工具。它的设计初衷是:根据元素的理论尺寸,自动为其测量尺寸分配合适的公差,而无需程序员手动为每个尺寸逐个设置。 范围设置区正是实现这一“自动匹配”逻辑的核心配置区域。PowerDMIS 的“自动公差 -…

作者头像 李华
网站建设 2026/4/11 0:45:55

大模型应用三定律丨工具、裁决、责任

大模型应用三定律 第零定律(元定律):人类文明至上 大模型的一切应用,不得损害人类文明的延续、繁荣与自主性。 (此定律高于一切,为隐含前提) 第一定律:工具性定律 大模型是非认知的符号处理器&#xff…

作者头像 李华
网站建设 2026/4/16 11:06:21

医疗超声波焊接技术案例是什么?德诺超声波(DELOK)在医疗产品焊接中的应用主要有那些?

医疗超声波焊接技术在医疗行业中逐渐成为一种重要的制造手段,因其高效性和可靠性而受到广泛关注。以德诺超声波(DELOK)为例,该技术能够快速而精准地完成医用产品的焊接。这包括了医疗器械的连接以及包装材料的密封。在实际应用中&…

作者头像 李华