git:指令集

以下是对这些 Git 新特性和命令的更详细解读和实际用例分析,帮助更好地理解它们的作用及适用场景:


1. git switchgit restore

背景:

  • 传统上,git checkout 是一个多功能命令,用于切换分支、检出文件、创建分支等,但其用途过于复杂,容易导致混淆。

新命令:

  • git switch:专注于切换分支。

    • 用法
      git switch branch-name  # 切换到指定分支
      git switch -c new-branch-name  # 创建并切换到新分支
      
    • 优点:避免因误用 git checkout 导致的文件检出错误。
  • git restore:专注于还原文件的修改。

    • 用法
      git restore file.txt  # 恢复工作目录中的指定文件
      git restore --staged file.txt  # 从暂存区移除文件的更改
      
    • 优点:明确分工,降低误操作的风险。

2. git worktree

背景:

  • 需要在一个仓库中同时处理多个分支时,频繁切换分支效率低,且可能导致未提交修改的丢失。

功能:

  • 允许在同一仓库中创建多个工作目录,每个目录可以检出不同的分支或提交。

用法

git worktree add ../path-to-new-worktree branch-name  # 创建新工作目录并检出分支
git worktree list  # 列出所有工作目录
git worktree remove ../path-to-new-worktree  # 删除指定的工作目录

场景:

  • 同时开发多个功能或修复多个问题,避免频繁切换分支或克隆多个仓库。

3. git sparse-checkout

背景:

  • 在处理大型代码仓库时,检出所有文件可能导致资源浪费或加载缓慢。

功能:

  • 支持稀疏检出,仅检出特定的文件或目录。

用法

git sparse-checkout init  # 初始化稀疏检出模式
git sparse-checkout set path/to/folder  # 设置稀疏检出的目录
git sparse-checkout add another/folder  # 添加更多目录到稀疏检出范围

场景:

  • 大型单体仓库(monorepo)开发中,仅需特定模块代码时。

4. git range-diff

背景:

  • 在变基或合并多个提交后,理解提交的差异和变化会变得复杂。

功能:

  • 对比两个提交范围的差异,帮助理解提交在变基或历史改写后的具体变化。

用法

git range-diff upstream..HEAD feature-branch  # 比较两个范围的差异

场景:

  • 代码审查过程中,分析变基后提交历史的变化。

5. git maintenance

背景:

  • 长期使用的仓库可能会出现性能问题,需要定期维护。

功能:

  • 提供自动化的维护任务,如压缩对象、优化文件等。

用法

git maintenance run  # 立即运行维护任务
git maintenance start  # 启用后台维护
git maintenance stop  # 停止后台维护

场景:

  • 在持续集成环境中,保持仓库高效性能。

6. git log --remerge-diff

背景:

  • 在调试复杂的合并历史时,需要了解某次合并引入的确切更改。

功能:

  • 重建合并提交,显示其引入的差异。

用法

git log --remerge-diff

场景:

  • 代码审查中,详细分析复杂合并带来的具体更改。

这些新命令和特性各自解决了开发流程中的实际痛点,大幅提升了 Git 的易用性和效率。在日常使用中,以下是常见组合:

  • 使用 git switchgit restore 替代 git checkout
  • 在大型项目中,结合 git worktreegit sparse-checkout 提高开发效率。
  • 使用 git maintenancegit log --remerge-diff 优化仓库性能和代码审查。

是 Git 的核心操作,用于处理分支切换、回退、更改历史记录以及查看操作记录等功能。以下是它们的作用和具体使用场景:


7. git checkout (切换分支或检出文件)

场景 1:切换分支

# 切换到现有分支 "feature-branch"
git checkout feature-branch

场景 2:创建并切换到新分支

# 创建新分支 "new-feature" 并切换到该分支
git checkout -b new-feature

场景 3:恢复文件

# 恢复文件 "app.js" 到上一次提交的状态
git checkout HEAD app.js# 从其他分支检出某个文件
git checkout dev -- app.js

注意:

  • git checkout 功能繁多,可能导致误用,因此从 Git 2.23 开始,切换分支和检出文件的功能被拆分为 git switchgit restore

8. git reset (回退到指定提交)

作用:

  • 主要用于撤销提交或重置文件的状态。

三种模式:

  1. --soft:保留工作区和暂存区的更改,仅回退提交记录。

    git reset --soft HEAD~1  # 回退到上一个提交
    
  2. --mixed(默认):保留工作区的更改,但清空暂存区。

    git reset HEAD~1
    
  3. --hard:彻底回退,包括清空工作区的更改,无法恢复!

    git reset --hard HEAD~1
    

常用操作:

  • 回退到指定提交:
    git reset --hard commit-hash**仅从暂存区移除文件**
    git reset file.txt
    

注意:

  • reset 会修改提交历史,可能导致数据丢失,不适合已推送的分支。

9. git revert (撤销特定提交)

作用:

  • 创建一个新的提交来反向应用某次提交的更改。

reset 的区别:

  • revert 是安全操作,不会修改提交历史,适合已推送的分支。

用法:

  1. 撤销指定提交:

    git revert commit-hash
    
  2. 批量撤销多个提交:

    git revert commitA..commitB
    
  3. 自动跳过冲突提示:

    git revert commit-hash --no-edit
    

场景:

  • 修复已推送的错误提交。
  • 撤销特定功能或 Bug 修复。

10. git reflog (查看历史操作记录)

场景 1:查看所有操作记录

git reflog
  • 输出示例:
    abc1234 (HEAD -> main) HEAD@{0}: reset: moving to HEAD~1
    def5678 HEAD@{1}: commit: Fix a bug
    ghi9012 HEAD@{2}: checkout: moving from feature to main
    

场景 2:恢复误删分支

# 假设分支被删除,找到分支最后一次操作的 commit-hash
git reflog# 创建分支恢复到误删位置
git branch recovered-branch abc1234

场景 3:恢复误用 reset --hard 丢失的提交

# 找到丢失的提交的 commit-hash
git reflog# 回退到该提交
git reset --hard commit-hash

完整操作案例

案例 1:修复提交历史
  1. 假设你误提交了错误内容:
    git commit -m "Wrong changes"
    
  2. 使用 reset 回退到暂存区:
    git reset HEAD~1
    
  3. 修改文件后重新提交:
    git add file.txt
    git commit -m "Correct changes"
    

案例 2:撤销错误的合并
  1. 假设最近一次合并出现问题:
    git merge feature-branch
    
  2. 使用 revert 撤销合并:
    git revert -m 1 commit-hash
    

案例 3:恢复误删的分支
  1. 假设你意外删除了分支:
    git branch -d feature-branch
    
  2. 查找分支的最后一次操作记录:
    git reflog
    
  3. 恢复分支:
    git branch feature-branch commit-hash
    

案例 4:稀里糊涂丢了提交,如何恢复
  1. 假设你执行了以下命令丢失了更改:
    git reset --hard HEAD~2
    
  2. 查找丢失的提交:
    git reflog
    
  3. 恢复到丢失的提交:
    git reset --hard commit-hash
    
命令适用场景
checkout切换分支、恢复文件、查看特定提交的文件内容。
reset回退到某个提交,修改提交历史(慎用在已推送分支)。
revert撤销特定提交的更改,生成新的提交(安全撤销)。
reflog查看本地分支的所有操作记录,恢复被误删除或回退的提交。

HEAD 的作用

HEAD 是 Git 中的一个特殊的指针,它始终指向当前活动分支的最新提交。可以理解为 Git 用来追踪“当前工作位置”的标记。通过操作 HEAD,我们可以切换分支、回退提交、检出历史版本等。


HEAD 的主要特性

  1. 指向当前分支的最新提交:

    • 在分支上工作时,HEAD 通常指向该分支的名称,例如 maindev 等。
    • 例如:
      HEAD -> main
      
    • 这表示当前 HEAD 绑定到 main 分支,而 main 分支指向它的最新提交。
  2. 可临时指向特定提交:

    • 如果使用 git checkout 检出一个历史提交,HEAD 会处于“分离状态”(detached HEAD),直接指向该提交的哈希值,而不再绑定到某个分支。

HEAD 的作用和常见场景

1. 检出分支
  • 当切换到某个分支时,HEAD 更新为指向该分支的最新提交。
git checkout main
  • 此时,HEAD -> main,表示当前工作目录的内容基于 main 分支。

2. 回退提交
  • 使用 git reset 时,HEAD 可以移动到历史的某个提交。
git reset --hard HEAD~1
  • 此操作将 HEAD 指针向回移动一位,同时更新当前分支。

3. 查看历史提交
  • 通过 HEAD 指向的提交哈希值,可以检出历史版本。
git checkout HEAD~2  # 检出当前分支的前两次提交
  • 此时,HEAD 处于分离状态。

4. 分离 HEAD 状态(Detached HEAD)
  • 如果 HEAD 不再指向分支,而是直接指向某个提交哈希值,就进入了分离状态:
git checkout commit-hash
  • 此时的 HEAD
    HEAD detached at commit-hash
    
  • 分离状态常用于查看历史版本或基于某次提交新建分支。

5. 临时恢复文件
  • 使用 HEAD 恢复工作区文件到最新提交状态:
git checkout HEAD -- file.txt
  • 该命令会将 file.txt 恢复到当前提交时的状态。

6. 参考点操作

HEAD 作为当前分支的参考点,可用于多种操作:

命令描述
HEAD~1当前提交的父提交。
HEAD~2当前提交的祖父提交。
HEAD^当前提交的第一个父提交(等价于 HEAD~1)。
HEAD^2当前提交的第二个父提交(用于合并提交)。
HEAD@{n}当前分支的 reflog 中第 n 次变更位置。

HEAD 的常见使用示例

场景 1:快速回到最新提交
  • 如果你临时查看了历史提交,想返回最新的提交:
git checkout main
场景 2:撤销最近一次提交,但保留工作区更改
git reset HEAD~1
场景 3:回退到分支的某个历史状态
git reset --hard HEAD~3
场景 4:对比当前工作区和最新提交的差异
git diff HEAD
场景 5:恢复文件到上次提交的状态
git checkout HEAD -- file.txt
场景 6:创建分支基于特定提交
  • 假设当前 HEAD 在分离状态,想基于它创建新分支:
git checkout -b new-branch

注意事项

  1. 分离状态的风险:

    • 在分离状态中,如果你没有创建新分支,做的所有提交都可能丢失。
    • 建议在需要继续工作的场景下,创建新分支:
      git checkout -b temp-branch
      
  2. HEAD 相关的误操作:

    • 使用 git reset --hard 修改 HEAD 时,要谨慎操作,避免丢失工作区的更改。

什么是分离状态(Detached HEAD)?

通常情况下,HEAD 是指向一个分支的,比如 mainfeature-branch。当你在某个分支上工作时,HEAD 会跟踪该分支的最新提交。

但是,当你检出(checkout)一个具体的提交哈希值,而不是分支名时,HEAD 就直接指向该提交,而不是分支。这就是所谓的“分离状态”。


为什么叫分离状态?

在分离状态下:

  1. HEAD 不再跟踪任何分支,而是直接指向某个具体的提交。
  2. 你可以查看或修改代码,但这些更改不会被关联到任何分支上,除非你创建一个新的分支。

如何进入分离状态?

分离状态通常发生在以下情况下:

1. 检出一个具体的提交
git checkout commit-hash
  • 这会让 HEAD 指向指定的提交,而不是当前分支的最新提交。
2. 检出一个标签(Tag)
git checkout v1.0.0
  • 标签通常指向一个具体的提交,检出标签也会导致 HEAD 分离。
3. 检出远程分支未合并的提交
git checkout origin/feature-branch
  • 如果本地没有该分支,直接检出远程分支的提交也会导致分离状态。

分离状态下会发生什么?

  1. 查看代码是安全的:

    • 你可以安全地查看指定提交的代码,不会对其他分支造成影响。
  2. 提交的更改可能丢失:

    • 如果你在分离状态下修改代码并提交:
      git commit -m "Work in detached HEAD"
      
      这些更改不会自动关联到任何分支,可能导致提交变得“孤立”。
  3. 你需要创建新分支保存工作:

    • 如果不想丢失提交,需要创建一个新分支:
      git checkout -b new-branch
      

分离状态的工作流程

例子:检出历史提交

假设当前分支是 main,它的提交历史如下:

A -> B -> C -> D (HEAD, main)

你运行以下命令:

git checkout B

此时:

  1. HEAD 会直接指向提交 B
  2. main 分支仍然指向提交 D
  3. 工作区的代码被恢复为提交 B 的状态。

结果:

A -> B (HEAD) -> C -> D (main)

如果你在这个状态下修改文件并提交:

git commit -m "New commit"

提交历史会变成这样:

A -> B -> E (HEAD) -> C -> D (main)

注意: 提交 E 不属于任何分支,是孤立的。

解决孤立提交:
  1. 如果你想保留提交 E,需要创建一个新分支:

    git checkout -b temp-branch
    

    新分支 temp-branch 会指向提交 E,保留你的工作。

  2. 如果你直接切换到其他分支而没有保存,提交 E 会被垃圾回收机制清理掉。


如何离开分离状态?

如果你不打算保留分离状态下的任何修改,可以直接切换回分支:

git checkout main

分离状态的注意事项

  • 分离状态适合以下场景:

    • 检查代码在特定历史版本中的状态。
    • 调试某个历史提交。
    • 基于某个历史提交开始新的开发。
  • 不适合长期工作:

    • 因为分离状态的更改不被分支记录,很容易导致工作丢失。

总结

当你在分离状态下,HEAD 不再绑定到某个分支,而是直接指向某个提交。虽然你可以修改和提交代码,但这些提交是孤立的,必须创建新分支来保存。分离状态通常用于查看或临时操作历史版本,但需要注意保存工作,以免丢失更改。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/501950.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【2025最新计算机毕业设计】基于Spring Boot+Vue影院购票系统(高质量源码,提供文档,免费部署到本地)

作者简介:✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流。✌ 主要内容:🌟Java项目、Python项目、前端项目、PHP、ASP.NET、人工智能…

数据安全防护

数据安全防护有几个层面 边界安全 网络防火墙负责的部分 认证 kerberos负责的部分 授权 识别用户是否有访问某个模块的权限 认证是kerberos负责的事情 1. 客户端请求认证服务器,希望得到访问服务端票据的票据 2.客户端拿到访问服务端票据的票据后,去…

Cursor连接腾讯云Cloud Studio开发环境

文章目录 环境准备Cloud StudioCursor Cursor连接Cloud Studio开发环境 环境 腾讯云Cloud Studio语言模板All In One实例Windows 11Firefox 133.0.3 (64 位)Cursor 0.44.9 准备 Cloud Studio 在腾讯云Cloud Studio( https://ide.cloud.tencent.com/ &#xff09…

【工具整理】WIN换MAC机器使用工具整理

最近公司电脑升级,研发同学统一更换了 Mac Book Pro 笔记版电脑,整理一下安装了那些软件以及出处,分享记录下~ 知识库工具 1、语雀 网址:语雀,为每一个人提供优秀的文档和知识库工具 语雀 个人花园&…

面试题解,Java中的“对象”剖析

一、说一说JVM中对象的内存布局?new一个对象到底占多大内存? 话不多说,看下图,对象的内存布局图 一个对象的内存布局主要由三部分组成:对象头(Object Header)、实例数据(Instance D…

大白话拆解——多线程中关于死锁的一切(七)(已完结)

前言: 25年初,这个时候好多小伙伴都在备战期末 小编明天还有一科考试,日更一篇,今天这篇一定会对小白非常有用的!!! 因为我们会把案例到用代码实现的全过程思路呈现出来!&#xff…

家教老师预约平台小程序系统开发方案

家教老师预约平台小程序系统将连接学生/家长与家教老师,提供一站式的家教服务预约体验。 一、用户需求分析1、家教老师:希望获得更多的学生资源,通过平台展示自己的教学特长和经验,管理个人日程,接收并确认预约请求&a…

windows 图形基础架构简介

背景 本文尝试对Windows系统中的一些Graphic相关的概念进行介绍和厘清。 windows图形基础架构简介 Windows 为图形提供了多个 API,下图显示了这些 API。 上图出自微软官方https://learn.microsoft.com/en-us/windows/win32/learnwin32/overview-of-the-windows-…

QML使用Popup实现弹出Message

方案一:popup import QtQuick 2.15 import QtQuick.Controls 2.15 import QtQuick.Layouts 1.15ApplicationWindow {visible: truewidth: 640height: 480title: qsTr("Top Message Popup Example")ColumnLayout {anchors.centerIn: parentspacing: 10Butt…

Ⅱ.INTRODUCTION TO CUDA C

前言 上一节环境配置好了,我们开始吧! 一、A First Program 1. Hello, World! 我们先写一个C语言的 Hello, World! 作为对比 int main(void){printf("Hello, World!\n");return 0; }大家应该知道这个代码运行在CPU上吧,我们CP…

如何轻松关闭 iPhone 上的 HEIC [HEIC 图像技巧]

您是否正在为关闭 iPhone 上的 HEIC 而烦恼?你不是一个人; Apple 的首选图像文件格式仍可能存在一些兼容性问题。当您与某人共享照片或尝试在Windows计算机上打开图像时,就会出现此问题。幸运的是,Apple 使关闭 HEIC iPhone 变得更加容易。 …

Postgresql 命令还原数据库

因为PgAdmin打不开,但是数据库已经安装成功了,这里借助Pg命令来还原数据库 C:\Program Files\PostgreSQL\15\bin\psql.exe #链接数据库 psql -U postgres -p 5432#创建数据库 CREATE DATABASE "数据库名称"WITHOWNER postgresENCODING UTF8…

docker中使用Volume完成数据共享

情景概述 在一个docker中,部署两个MySQL容器,假如它们的数据都存储在自己容器内部的data目录中。这样的存储方式会有以下问题: 1.无法保证两个MySQL容器中的数据同步。 2.容器删除后,数据就会丢失。 基于以上问题,容…

vue——滑块验证

1. 介绍 1.1 简介 基于滑动式的验证码,免于字母验证码的繁琐输入 用于网页注册或者登录 1.2 来源说明 vue使用滑块验证功能,是基于vue-monoplasty-slide-verify这样的一个开源项目,进行实现的,这是这个开源项目的网址传送阵&#…

如何很快将文件转换成另外一种编码格式?编码?按指定编码格式编译?如何检测文件编码格式?Java .class文件编码和JVM运行期内存编码?

如何很快将文件转换成另外一种编码格式? 利用VS Code右下角的"选择编码"功能,选择"通过编码保存"可以很方便将文件转换成另外一种编码格式。尤其,在测试w/ BOM或w/o BOM, 或者ANSI编码和UTF编码转换,特别方便。VS文件另…

Unity3D仿星露谷物语开发16之角色拾取道具

1、目标 当角色经过道具时会拾取道具放到库存列表中,此时道具消失并打印库存信息。 2、创建新的Enum 在Assets -> Scripts -> Enums -> Enum.cs中添加库存位置相关的信息。 public enum InventoryLocation {player, // 在角色手中chest, // 在箱子里co…

UE4_用户控件_3_用户控件输入数据的方法

祝愿大美兰陵越来越好! 一、效果展示: 二、先制作一个角色 1、新建个父类为pawn的蓝图类。更名为BP_Image_Character。 2、这个角色只是用于观察场景,并与场景中的物体相碰撞用的,所以不需要骨骼网格体, 3、但是我们…

文献阅读 | B. S. Carmo 2010

目录 一、文献名称二、原文地址三、ABSTRACT主要发现详细观察分岔分析雷诺数依赖性比较见解意义结论 四、IINTRODUCTION历史研究回顾计算研究近期研究进展研究空白与目的论文结构 一、文献名称 二、原文地址 研究目的:研究串列排列双圆柱体周围流场中的次级不稳定性…

vue3 css实现文字输出带光标显示,文字输出完毕,光标消失的效果

Vue实现过程如下&#xff1a; <template><div ><p ref"dom_element" class"typing" :class"{over_fill: record_input_over}"></p></div> </template> <script setup> import {onMounted, ref} from…

如何安装适配pytorch版本的torchvision

一、对照版本 版本对照pytorch/vision: Datasets, Transforms and Models specific to Computer Vision 二、下载对应版本的torchvision 下载连接1download.pytorch.org/whl/torch_stable.html 下载连接2download.pytorch.org/whl/cu110/torch_stable.html 笔者认为1会比2更…