2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

Git 实用技巧和命令

  • 2018-08-10
  • 本文字数:2004 字

    阅读完需:约 7 分钟

Git 是一个非常强大的工具,它包含丰富的工具用以维护项目。本文我们将会看见一些 Git 日常使用过程中的实用技巧和命令。希望其中的一些内容能够对读者有所帮助。

Git diff

通常情况下,我们会在自己的独立分支中完成需求开发,此时就会有需求将自己的分支和其他分支进行对比。这个功能可以通过

复制代码
git diff branch1 branch

命令来实现。

如果希望对比暂存区和当前的 HEAD,那么使用

复制代码
git diff --cached

命令会非常方便。普通的git diff命令默认对比的是没有加到索引中的文件。

恢复暂存区

如果已经将一些文件添加到暂存区后又后悔了,Git 提供了多个命令来实现这个功能,具体需要根据当时情况而定。

复制代码
git rm path/to/file --cached

命令将文件从暂存区索引中删除,但是仍然会将文件保留在工作目录。这比直接使用

复制代码
git rm file -f

命令完全删除文件会安全一点。

Git reset

如果希望恢复一些已经提交的改动,我们可以使用

复制代码
git reset

命令。该命令有许多不同的行为,因此需要按照实际场景进行使用。

如果希望的是去除所有修改,包括索引中的内容和工作目录中的修改,那么可以使用

复制代码
git reset --hard

如果仅仅是希望重置索引,那么可以使用

复制代码
git reset --mixed

命令,这也是 git reset 命令的默认行为。混合的重置会保留当前工作目录中的改动。最后,如果仅仅希望修改分支的 HEAD,可以通过

复制代码
git reset --soft

实现。

当运行 git reset 命令的时候,我们可以指定多个目标文件作为参数传入。当然可以通过

复制代码
git reset --hard COMMIT_ID

恢复到指定的提交版本。

Git stash

大家应该对 git stash 命令并不陌生,它可以通过 git stash pop 命令方便的将之前的改动恢复回来。然而,如果工作目录中有未追踪的文件,默认情况下是不会将其存入临时储藏区的。为了能够临时保存未追踪的文件,可以使用

复制代码
git stash --include-untracked

命令。另外一个非常有用的命令是

复制代码
git stash list

它能列出临时储藏区中的内容。

历史记录

Git 自带了非常强大的工具来查看项目以及特定文件的变更情况。我个人非常喜欢用其中的一个命令:

复制代码
git log --graph --decorate --oneline

用以展示经过修饰的提交历史。这个命令非常冗长,因此我建议可以为它创建一个别名(这可能是所有技巧中最有用的,因为许多命令都比较难记)。git log 命令可以显示 HEAD、所有提交的 ID 以及分支信息。有了这些信息之后,我们可以使用

复制代码
git show COMMIT_ID/HEAD/BRANCH

命令来显示更详细的信息。

有的时候我们需要了解谁对一个文件做了哪些改动,这正是

复制代码
git blame path/to/file

命令所提供的功能。

之前提到过 git diff 命令,它也是一个查看历史的工具。例如,如果需要对比当前 HEAD 和前两个提交,可以使用

复制代码
git diff HEAD HEAD~2

为了能够展示每个提交中的更详细的更新信息,可以使用

复制代码
git log --patch

命令。如果只想要看包含关键字“apple”的提交,使用

复制代码
git log --grep apples --oneline

命令。

需要查看历史提交记录中两个点之间的提交历史,我们可以用

复制代码
git log HEAD~5..HEAD^ --oneline

命令,对于分支可以使用

复制代码
git log branch_name..master --oneline

修复错误提交

注意:以下一些命令会修改提交历史,使用前请确保了解后再执行。

当提交出错时,我们可能会希望能够修改提交历史。我不建议修改已经推送到远程仓库的提交历史(即使 git 允许这样做),但是对于本地仓库的提交历史,我个人认为还是可以修改的。通过

复制代码
git commit --amend

命令可以删除前一次提交,并创建一个新的提交记录以替代之前的提交。

另一个我最喜欢的 git 使用技巧是交互式变基 (rebase)。它可以用来编辑提交信息,或者将多个提交压缩成一个提交,这也是我最喜欢的一个功能。为了在远程仓库 origin 的 master 分支之后的所有提交上执行交互式变基,可以使用

复制代码
git rebase -i origin/master

该命令会显示提交列表和可执行操作的详细描述。例如以下操作将会把多个提交压缩成一个:

复制代码
1 pick 80f2a48 Add feature X
复制代码
2 squash 2c74ea2 Add junit tests for feature X
复制代码
3 squash 4k81nm5 Bugfix for feature X

最终的结果会是生成一个提交消息为“Add feature X”的提交。

如果需要恢复一个有问题的提交,我们可以使用

复制代码
git revert COMMIT_ID

该命令会创建一个新的提交,让当前项目状态恢复到指定提交之前。

如果我们在修复问题时出现了误操作,例如不小心删除了不应该删除的文件。我们还是可以从版本库中恢复回来,因为 git 保存了所有修改的版本,包括被移除的提交。git reflog 命令就是用来实现这个功能的。

挑拣提交(cherry-pick)

假设我们和同事在各自单独的分支上进行开发,同事有一个重要的提交我们也想应用到自己的分支上来,但是不需要对方分支的其他提交。这时我们可以使用

复制代码
git cherry-pick COMMIT_ID

后记

以上都是我最喜欢的 git 实用技巧。希望你也能从中学到一些新知识。这些都是我在日常使用中发现非常有用的命令,它们对我的日常工作非常有用。如果你也有类似常用的 git 实用技巧或者常用命令,可以分享出来大家一起交流。

查看英文原文: Useful Git Tips and Commands

2018-08-10 02:323394

评论

发布
暂无评论
发现更多内容

小程序+自定义插件的关键性

Geek_99967b

小程序

大型分布式存储方案MinIO介绍,看完你就懂了!

天使不哭

存储 MINO #开源 8月月更

5个 Istio 访问外部服务流量控制最常用的例子,你知道几个?

万猫学社

云原生 istio envoy Istio流量管理

开源一夏 | 对于Angular表达式以及重要指令的研究心得【前端实战Angular框架】

恒山其若陋兮

开源 8月月更

shell之变量详解,让你秒懂!

Albert Edison

Linux centos 运维 shell脚本编程 8月月更

2022 首期线下 Workshop!面向应用开发者们的数据应用体验日来了 | TiDB Workshop Day

TiDB 社区干货传送门

在“企业通讯录”的盲区,融云的边界与分寸

融云 RongCloud

企业 IM im开发

2022Nginx实战教程,由浅入深

LoneWalker、

nginx

Java技术:SpringBoot实现邮件发送功能

天使不哭

Java email #开源 8月月更

SpringMVC(三、JDBCTemplate)

开源 springmvc 8月月更

跨端技术方案选什么好?

Geek_99967b

跨端

视频是主动学习吗?

FunTester

图解VirtualBox安装CentOS 7

万猫学社

Centos 7 virtualbox

README_Albumentations

G_Meteor

每日一R「02」所有权与 Move 语义

Samson

签约计划第三季 8月月更 ​Rust

基于设计稿识别的可视化低代码系统实践

Shopee技术团队

前端 设计 低代码

ebook下载 | 《 企业高管IT战略指南——企业为何要落地DevOps》

York

云计算 DevOps 云原生 数字化转型 降本增效

重要的不是成为海贼王,而是像路飞一样去冒险

沃德

FileZilla搭建FTP服务器图解教程

天使不哭

#开源 8月月更

带着昇腾去旅行:一日看尽金陵城里的AI胜景

脑极体

开源一夏 | Mysql开启ssl加密协议及Java客户端配置操作指南

六月的雨在InfoQ

MySQL 开源 SSL证书 SSL 连接 8月月更

十步以内,用小程序快速生成App!

Geek_99967b

小程序

分享 6 个 Vue3 开发必备的 VSCode 插件

Geek_z9ygea

vue.js 前端 vscode vuejs

操作系统:SSH协议知识介绍

天使不哭

Linux SSH #开源 8月月更

10个 Istio 流量管理 最常用的例子,你知道几个?

万猫学社

云原生 istio envoy Istio流量管理

“稚晖君”为2022昇腾AI创新大赛打call 期待广大开发者加入

极客天地

“车家互联”新态势,小程序实现物联网多场景互通

Speedoooo

小程序 智能家居 小程序容器 电动车

阿里云架构师金云龙:基于云XR平台的视觉计算应用部署

阿里云弹性计算

视觉计算 计算巢 云XR平台 GPU实例

开发者必备:一文快速熟记【数据库系统】和【软件开发模型】常用知识点

小阿杰

软件开发流程 软件开发原则 数据库系统 签约计划第三季

为什么数字钱包需要引入小程序生态

Speedoooo

小程序 第三方支付 小程序容器 移动钱包

Git实用技巧和命令_Git_viktor_InfoQ精选文章