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:323384

评论

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

PDF编辑软件Acrobat Pro DC 2023 最新版+如何取消Acrobat更新教程

Rose

Acrobat Pro DC 2023 Acrobat Pro DC更新 如何取消Acrobat 自动更新

Java异常Exception详解

timerring

Java 三周年连更

好家伙!阿里新产Java性能优化(终极版),涵盖性能优化所有操作

程序员小毕

数据库 性能优化 JVM 多线程 java面试

基于UDP协议的Socket通信

芯动大师

UDP协议 客户端配置 三周年连更

基于Flutter实现跨平台离线大模型对话应用

轻口味

flutter ios android AI 三周年连更

使用 Amazon SageMaker 构建文本摘要应用

亚马逊云科技 (Amazon Web Services)

告别祈祷式编程|单元测试在项目里的正确落地姿势

浅羽技术

Java 测试 单元测试 JUnit 三周年连更

Django笔记十一之外键查询优化select_related和prefetch_related

Hunter熊

Python django 外键查询优化 select_related prefetch_related

Docker容器网络的七种武器

王玉川

Docker 容器 网络 VXLAN 网络虚拟化

浅论分布式训练中的recompute机制

百度Geek说

机器学习 深度学习 分布式 企业号 4 月 PK 榜

近期Master分支代码编译异常的解决方案

坚果

OpenHarmony OpenHarmony3.2 三周年连更

如何让 Windows 应用程序在 Parallels Desktop 中启动得更快

Rose

pd虚拟机 pd18虚拟机 Parallels Desktop启动

基于树莓派设计的音视频播放器(从0开始)

DS小龙哥

三周年连更

PicConvert for mac:以批处理模式转换,调整大小和重命名图像

Rose

苹果软件资源 图片格式转换 PicConvert mac mac图片编辑

SpringBoot如何使用Jetty容器?超级详细,建议收藏

bug菌

springboot jetty 三周年连更

从多个数据源中提取数据进行ETL处理并导入数据仓库

海拥(haiyong.site)

三周年连更

深入剖析Go语言中的Channel:高级特性与注意事项

Jack

逐渐消失的站长圈子,未来个人站长如何转型

石头IT视角

Unity 之 查找游戏物体的几种方式汇总解析

陈言必行

Unity 三周年连更

图计算引擎分析--GridGraph

京东科技开发者

系统 磁盘 图计算引擎 企业号 4 月 PK 榜 GridGraph

通俗易懂篇:贝叶斯网络和它的应用

Bob

网络 贝叶斯算法

强大易用的矢量图形设计工具Sketch v96.1最新中文版

Rose

苹果软件下载 Sketch中文版 Sketch V96.1 mac图形设计工具

Mac音频采样器Kontakt 7最新版v7.3.0下载

Rose

mac音频采样器 Kontakt 7激活版 Native Instruments Kontakt 7 mac下载

2023年超全前端面试题-背完稳稳拿offer(欢迎补充)

肥晨

三周年连更

Lambda 应用介绍及实现原理剖析

架构精进之路

Java 后端 Lamdba表达式 三周年连更

跨平台应用开发进阶(五十一):HTML5(富文本内容)连续数字、字母不自动换行问题分析及解决

No Silver Bullet

html5 跨平台应用开发 三周年连更 问题分析及解决

vue3学习-Composition API

格斗家不爱在外太空沉思

Vue 3 三周年连更

一种面向后端的微服务低代码平台架构设计

京东科技开发者

架构 微服务 低代码 企业号 4 月 PK 榜

Shell在日常工作中的应用实践

京东科技开发者

Linux Shell 服务器 shell脚本编程 企业号 4 月 PK 榜

一文读懂物联网 MQTT 协议之基础特性篇

老周聊架构

三周年连更

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