当前位置: 首页 > news >正文

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

相关文章:

git:指令集

以下是对这些 Git 新特性和命令的更详细解读和实际用例分析,帮助更好地理解它们的作用及适用场景: 1. git switch 和 git restore 背景: 传统上,git checkout 是一个多功能命令,用于切换分支、检出文件、创建分支等&…...

自闭症家庭:建立支持系统与平衡生活

在自闭症家庭的世界里,每一天都充满了挑战与希望。自闭症,这一复杂的神经发育障碍,不仅影响着孩子的成长轨迹,也对整个家庭的生活方式产生了深远的影响。面对这一挑战,许多家庭都在努力寻找有效的支持系统和平衡生活的…...

html+css+js网页设计 美食 美食天下2个页面(里面包含php和mysql)

htmlcssjs网页设计 美食 美食天下2个页面(里面包含php和mysql) 网页作品代码简单,可使用任意HTML辑软件(如:Dreamweaver、HBuilder、Vscode 、Sublime 、Webstorm、Text 、Notepad 等任意html编辑软件进行运行及修改编…...

高阶知识库搭建实战七、(知识库雏形开发:qianwen-plus+Faiss)(练习推荐)

构建知识库:结合Faiss和qianwen-plus大模型的实践 环境搭建参考前面几篇文章:基础环境搭建、Faiss向量数据库安装 在当今信息爆炸的时代,如何高效地管理和检索海量知识成为了一个重要课题。知识库的构建为我们提供了一种有效的解决方案,它能够将分散的信息整合起来,方便…...

麒麟服务器安装kafka--亲测

我这安装的是单机版本的: 下载地址:Index of /kafka/3.9.0 我下载的是:https://dlcdn.apache.org/zookeeper/zookeeper-3.9.3/apache-zookeeper-3.9.3-bin.tar.gz https://dlcdn.apache.org/kafka/3.9.0/kafka_2.12-3.9.0.tgz 一、下载并上…...

微机——8086微处理器的数据传送指令

目录 数据传送指令: 通用数据传送指令: MOV指令: 堆栈操作指令: PUSH指令: POP指令: 交换指令XCHG: XCHG指令: 换码指令XLAT: 换码指令XLAT: 8086 …...

vue3中onUpdated钩子函数和nextTick的具体使用场景和区别

在 Vue 3 中,onUpdated 钩子函数和 nextTick 方法都用于处理 DOM更新后的操作,但它们的使用场景和触发时机有所不同。以下是它们的具体使用场景和区别,结合代码示例进行解释: onUpdated 钩子函数 使用场景:适用于需要…...

colnames看似简单,却能优化数据处理流程

引言 在数据处理和分析中,变量名称是至关重要的,它们决定了数据的可读性和操作的简便性。在R语言中,colnames 函数以其简单的语法设计,提供了高效管理数据框列名的能力,尤其是在复杂的爬虫任务中显得尤为重要。本篇文…...

欧几里得距离在权重矩阵中的物理意义

欧几里得距离在权重矩阵中的物理意义 目录 欧几里得距离在权重矩阵中的物理意义**衡量神经元差异程度**:**反映模型变化程度**:**聚类和分组的依据**:自然语言处理中的模型更新:**神经网络聚类分组**:欧几里得距离在权重矩阵中的物理意义衡量神经元差异程度: 在神经网络中…...

AI编程辅助开发网站

咋用AI工具快速鼓捣出个网站? 咱都知道,现在这年月,干啥都讲究个效率,做网站更是如此。好在有了那些AI小帮手,不管你是专业搞开发的老手,想让活儿干得更快些,还是从没做过网站的小白&#xff0…...

「Mac畅玩鸿蒙与硬件53」UI互动应用篇30 - 打卡提醒小应用

本篇教程将实现一个打卡提醒小应用,通过用户输入时间进行提醒设置,并展示实时提醒状态,实现提醒设置和取消等功能。 关键词 打卡提醒状态管理定时任务输入校验UI交互 一、功能说明 打卡提醒小应用包含以下功能: 提醒时间输入与…...

基于单片机洗衣机控制器的设计(论文+源码)

1需求分析 在智能洗衣机系统设计中,考虑到洗衣机在实际应用过程中,需要满足用户对于不同衣物清洁、消毒的应用要求,对设计功能进行分析,具体如下: 通过按键实现洗衣机不同工作模式的切换,包括标准模式&…...

【Git系列】解析与解决Git错误:RPC失败;curl 56 OpenSSL SSL_read: error:140943FC

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...

[Unity Shader] 【游戏开发】Unity基础光照1-光照模型原理

在计算机图形学中,渲染是一个复杂的过程,包含了两个主要部分:决定一个像素的可见性和计算该像素的光照。其中,光照模型是渲染过程中的核心部分,它模拟了真实世界中的光与物体表面的交互,帮助生成最终的图像。在Unity等游戏引擎中,理解光照模型的原理是创建真实感视觉效果…...

基于Python 的宠物管理系统(源码+部署)

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…...

console.log封装

console.log封装 在控制台中打印带有颜色和格式的日志信息。 /*** 检查给定的对象是否为数组*/ const isArray function (obj: any): boolean {return Object.prototype.toString.call(obj) [object Array] }/*** Logger 构造函数*/ Logger () > {}/*** 根据日志类型返回…...

戴尔/Dell 电脑按什么快捷键可以进入 Bios 设置界面?

BIOS(基本输入输出系统)是计算机硬件与操作系统之间的桥梁,它负责初始化和测试系统硬件组件,并加载启动操作系统。在某些情况下,如调整启动顺序、更改系统时间或日期、修改硬件配置等,您可能需要进入BIOS进…...

GitLab创建用户,设置访问SSH Key

继上一篇 Linux Red Hat 7.9 Server安装GitLab-CSDN博客 安装好gitlab,启用管理员root账号后,开始创建用户账户 1、创建用户账户 进入管理后台页面 点击 New User 输入用户名、邮箱等必填信息和登录密码 密码最小的8位,不然会不通过 拉到…...

Mysql--基础篇--SQL(DDL,DML,窗口函数,CET,视图,存储过程,触发器等)

SQL(Structured Query Language,结构化查询语言)是用于管理和操作关系型数据库的标准语言。它允许用户定义、查询、更新和管理数据库中的数据。SQL是一种声明性语言,用户只需要指定想要执行的操作,而不需要详细说明如何…...

比较 FreeSWITCH 的 asr 事件和回调函数

用 lua 来描述,是这样的 第一种做法: session:setVariable("fire_asr_events", "true") session:execute("detect_speech", "start-input-timers") 识别到结果之后可以收到 DETECTED_SPEECH 事件 另外一个做法…...

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…...

stm32G473的flash模式是单bank还是双bank?

今天突然有人stm32G473的flash模式是单bank还是双bank?由于时间太久,我真忘记了。搜搜发现,还真有人和我一样。见下面的链接:https://shequ.stmicroelectronics.cn/forum.php?modviewthread&tid644563 根据STM32G4系列参考手…...

利用ngx_stream_return_module构建简易 TCP/UDP 响应网关

一、模块概述 ngx_stream_return_module 提供了一个极简的指令&#xff1a; return <value>;在收到客户端连接后&#xff0c;立即将 <value> 写回并关闭连接。<value> 支持内嵌文本和内置变量&#xff08;如 $time_iso8601、$remote_addr 等&#xff09;&a…...

为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?

在建筑行业&#xff0c;项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升&#xff0c;传统的管理模式已经难以满足现代工程的需求。过去&#xff0c;许多企业依赖手工记录、口头沟通和分散的信息管理&#xff0c;导致效率低下、成本失控、风险频发。例如&#…...

Yolov8 目标检测蒸馏学习记录

yolov8系列模型蒸馏基本流程&#xff0c;代码下载&#xff1a;这里本人提交了一个demo:djdll/Yolov8_Distillation: Yolov8轻量化_蒸馏代码实现 在轻量化模型设计中&#xff0c;**知识蒸馏&#xff08;Knowledge Distillation&#xff09;**被广泛应用&#xff0c;作为提升模型…...

C++:多态机制详解

目录 一. 多态的概念 1.静态多态&#xff08;编译时多态&#xff09; 二.动态多态的定义及实现 1.多态的构成条件 2.虚函数 3.虚函数的重写/覆盖 4.虚函数重写的一些其他问题 1&#xff09;.协变 2&#xff09;.析构函数的重写 5.override 和 final关键字 1&#…...

C#中的CLR属性、依赖属性与附加属性

CLR属性的主要特征 封装性&#xff1a; 隐藏字段的实现细节 提供对字段的受控访问 访问控制&#xff1a; 可单独设置get/set访问器的可见性 可创建只读或只写属性 计算属性&#xff1a; 可以在getter中执行计算逻辑 不需要直接对应一个字段 验证逻辑&#xff1a; 可以…...

【无标题】路径问题的革命性重构:基于二维拓扑收缩色动力学模型的零点隧穿理论

路径问题的革命性重构&#xff1a;基于二维拓扑收缩色动力学模型的零点隧穿理论 一、传统路径模型的根本缺陷 在经典正方形路径问题中&#xff08;图1&#xff09;&#xff1a; mermaid graph LR A((A)) --- B((B)) B --- C((C)) C --- D((D)) D --- A A -.- C[无直接路径] B -…...

【前端异常】JavaScript错误处理:分析 Uncaught (in promise) error

在前端开发中&#xff0c;JavaScript 异常是不可避免的。随着现代前端应用越来越多地使用异步操作&#xff08;如 Promise、async/await 等&#xff09;&#xff0c;开发者常常会遇到 Uncaught (in promise) error 错误。这个错误是由于未正确处理 Promise 的拒绝&#xff08;r…...

在 Spring Boot 中使用 JSP

jsp&#xff1f; 好多年没用了。重新整一下 还费了点时间&#xff0c;记录一下。 项目结构&#xff1a; pom: <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://ww…...