首页 程序笔记 如何本地和远程删除 Git 中的分支

如何本地和远程删除 Git 中的分支

您删除 GitHub 中的分支的原因有多种。幸运的是,删除 Git 分支很容易。

要点

  • 删除分支是典型 Git 工作流程的重要组成部分。
  • 您可以使用命令“gitbranch -d [branchname]”删除本地分支,但要小心未合并的更改。
  • GitHub Desktop、GitKraken、Tower 和 Bitbucket 等不同工具都有自己的删除分支的方法,因此请熟悉每个工具的具体流程。

Git 的分支非常轻量级,因此您可以在需要时轻松创建它们。但也很容易最终得到不再需要的剩余分支。那么删除分支涉及什么?

为什么要删除分支?

首先,如果您仍在学习如何使用 git 分支构建项目,那么您很有可能创建一个分支,然后决定不需要这样做。这很好,因为分支是一种轻量级操作;它速度非常快并且可以有效地利用磁盘空间。

因此,许多 git 开发工作流程鼓励分支,即使对于非常小的或短的任务也是如此。例如,一个常见的策略是为每个错误修复创建一个单独的分支。

删除分支应该与创建分支一样成为日常工作流程的一部分。

带有分支的示例存储库

下面的示例引用了具有以下结构的示例存储库:

请注意,该存储库有两个分支:maindev。每个本地分支都是一个跟踪分支,在远程服务器()上有一个相应的上游分支。

很容易丢失分支的踪迹,因此请确保您知道如何从命令行列出 git 分支或在您的首选客户端中查看它们。

使用命令行删除分支

删除分支的基本命令语法是:

git branch (-d | -D) [-r] <branchname>...

如何删除本地分支

该命令的最简单形式会删除本地分支,前提是它的所有更改都已合并:

git branch -d dev

当一切顺利时,您会看到一条确认消息:

您无法删除当前处于活动状态的分支;如果您尝试这样做,您会收到如下消息:

如果您删除包含未合并、未推送更改的本地分支,您将丢失这些更改。因此,git默认会拒绝删除这样的分支。在此示例中,dev 未合并尚未推送到远程分支的更改:

正如错误消息所示,您可以使用 -D 标志强制删除。

如果本地跟踪分支对应的远程分支是最新的,即使它未合并,您也可以删除它。 Git 仍然会显示警告,因此您知道发生了什么:

如何删除远程分支

删除远程分支是完全不同的。您将使用 git push 命令和 -d 标志来删除。之后,提供远程名称(通常来源)和分支名称:

使用 GitHub Desktop 删除本地和远程分支

与命令行 git 程序不同,GitHub 的桌面应用程序只允许您删除活动分支。您可以通过分支菜单执行此操作,选择删除选项并确认:

GitHub Desktop 不允许您删除默认分支,例如main——尽管 git 本身也支持这一点。如果默认分支是当前活动的分支,则应用程序将禁用菜单操作。

如果该分支也代表远程分支,GitHub Desktop 也会提供从远程删除它的选项:

使用 GitKraken 删除分支

GitKraken 在左侧边栏中显示存储库的本地和远程分支。您必须分别删除每个。

将鼠标悬停在相应的分支名称上,然后单击看起来像三个垂直点的分支操作菜单。从菜单中选择删除<分支名称>

您将看到一条确认消息,通知您这是一个破坏性操作。您可以使用删除按钮确认您要继续:

为了反映 git 命令行程序的默认行为,您必须首先切换到要删除的分支以外的分支。否则,您会看到一条错误消息:

使用 Tower 删除本地和远程分支

使用 Tower 删除分支与使用 GitKraken 删除分支非常相似。该应用程序在左侧的面板中显示本地和远程分支。右键单击任何分支并从上下文菜单中选择“删除”选项:

一个关键区别是您可以在确认期间删除远程分支及其本地分支:

删除 GitHub 上的分支

GitHub 仅充当远程源,因此默认情况下那里的分支是远程的。如果您使用 GitHub 网站删除分支,则必须使用此处的其他方法之一删除相应的本地分支。

与 GitHub Desktop 应用程序一样,GitHub 网站不允许您删除默认分支。如果您尝试,您会看到一条错误消息:

然而,删除任何其他分支也很简单。在存储库的代码页面中,单击分支链接,找到要删除的分支,然后单击删除分支图标,该图标看起来像一个垃圾桶能:

请注意,不会检查未合并的更改,因此 GitHub 将立即删除分支。但是,由于它始终代表远程分支,因此这种行为应该是有意义的。

请注意,删除后,您将看到一个恢复分支的按钮。然而,这只是一个有用的撤消功能,以防万一您意外单击删除图标。不要依赖它,因为一旦您刷新或离开页面,您就会失去该选项!

删除 Bitbucket 上的本地和远程分支

Bitbucket 与 GitHub 一样,不允许您删除默认分支。 Bitbucket 在存储库设置中将其称为主分支。您可以通过相应的操作菜单删除分支选项卡上列出的任何其他分支:

如果您正在进行一项大型清理操作,您还可以一次删除多个分支:

删除分支是典型 Git 工作流程的一部分

Git 分支可能会使您的工作流程变得复杂,尤其是具有本地、远程和跟踪分支的工作流程。但对于简单的日常开发,您可能会一直创建和删除本地分支。这是您应该习惯的典型 git 工作流程的核心方面。

如果您发现很难准确记住如何删除分支,请考虑设置别名来删除分支并简化过程。


2

站心网

您删除 GitHub 中的分支的原因有多种。幸运的是,删除 Git 分支很容易。要点删除分支是典型 Git 工作流程的..

为您推荐

宝塔面板定时计划任务删除文件夹教程

1. 登录宝塔面板打开浏览器,输入宝塔面板的地址,使用你的用户名和密码登录。2. 进入计划任务在宝塔面板的左侧菜单中,找到并点击“计划任务”。3. 添加计划任务点击“添加计划任务”按钮。4. 配置计划任务任务类型..

ASP.NET如何将Views文件夹从项目分离

将 Views 文件夹从 ASP.NET 项目中分离是一个常见需求,比如为了实现模块化或分层架构。以下是实现此功能的完整步骤,从项目中分离 Views 文件夹,将其移到另一个独立的文件夹或项目中,并确保视图渲染仍然正常。1. ..

如何让AI写出Google认可的文章?

让 AI 写出 Google 认可的文章,核心在于满足 Google 的搜索排名算法要求。这些要求通常围绕以下几个关键点展开:内容质量、用户体验 和 SEO 优化。以下是详细指导:一、内容质量确保文章原创且有价值避免抄袭:Goog..

如何从.NET Framework迁移到.NET Core或.NET 6/7?

从 .NET Framework 迁移到 .NET Core 或 .NET 6/7 是一个提升性能和跨平台能力的关键过程。以下是迁移的主要步骤和注意事项:迁移步骤1. 评估当前项目依赖项检查:确保所有第三方库和NuGet包都有与 .NET Core/.NET 6..

如何优化ASP.NET Core应用的性能?

优化ASP.NET Core应用性能需要从代码、数据库、配置、服务器和部署等多个层面进行综合考虑。以下是一些优化ASP.NET Core应用性能的关键方法和技巧:1. 代码级优化使用异步编程:避免阻塞线程,通过async和await处理I..

.NET9 开始删除内置的 Swagger 支持 可使用Scalar.AspNetCore替代

Microsoft 已决定从 .NET 9 中删除内置的 Swagger 支持 (Swashbuckle)。为什么 Swagger (Swashbuckle) 被删除?ASP.NET Core 团队已决定从 .NET 9 中删除内置的 Swagger 支持 (Swashbuckle),原因如下:维护问..

chrome 开发者工具如何查看元素:hover时的样式

在 Chrome 开发者工具中查看元素的 :hover 样式,可以通过以下步骤实现:打开开发者工具:右键点击页面中的元素,然后选择“检查(Inspect)”或按下 F12 或 Ctrl + Shift + I (Windows) / Cmd + Option +..

.NET 9 即将推出的功能Task.WhenEach

.NET 爱好者!我刚刚偶然发现了一个非常酷的新 PR,它被合并到 .NET 运行时存储库中,我想分享一个例子。希望您能为新的 .NET 版本大肆宣传!在即将到来的 .NET 9 版本中,我们预计会有一个名为 .它在这里让您的异步..

针对 Go 语言开发的 SQL 驱动模拟库

数据库交互是几乎所有应用程序不可或缺的一部分,开发者们常常需要对数据库进行各种操作,包括插入、更新、删除和查询等。然而,在开发过程中直接对真实数据库进行操作不仅耗时耗力,还可能带来数据一致性和安全性的..

DockerUI 中文可视化Docker管理工具使用示例

DockerUI 是由国内开发者打造的一款优秀的 Docker 可视化管理工具。该工具拥有简洁直观的UI界面,可以轻松进行Docker主机管理、集群管理,以及Docker任务的编排等操作。DockerUI不仅展示了资源利用率、系统信息和更..

Blazor的N种渲染模式原理和常见问题说明

我们从下面这幅图开始,下图显示了三种渲染模式,分别称之为静态SSR、交互式SSR(即之前的BlazorServer)、交互式CSR(即之前的BlazorWasm)。还有一种渲染模式BlazorHybrid,稍后说。一、先浅层理解一个图例静态SSR:经..

前端CSS常见的三种设计模式

CSS设计模式主要包括OOCSS、SMACSS和BEMCSS等。以下是对这些模式的具体介绍:OOCSS:面向对象的CSS,旨在编写高可复用、低耦合和高扩展的CSS代码。它将抽象(结构)和实现(样式)分离,抽离公共代码,以提高代码的..

WinToUSB | 把Windows塞进U盘里即插即用

不论是在外出差,还是在家临时办公,现在很多设备携带起来都不是那么方便,在这种情况下,有一个轻巧而高效的操作系统环境就显得格外关键。今天,要给大家介绍一款超级实用的便携式系统启动盘,凭借其独特功能和卓越..

.NET Framework被淘汰了吗?

.NET Framework并未完全被淘汰,但它的某些版本确实已经停止支持。微软在2023年11月10日停止了对.NET Framework 4.8之前的版本的支持。这一决策意味着使用这些旧版本的应用程序将不再获得安全更新和其他维护,从而可..

强大的 .NET Mock 框架 单元测试模拟库Moq使用教程

单元测试是确保代码质量和可靠性的重要手段。当我们的代码依赖于外部系统、数据库或第三方服务时,编写有效的单元测试可能会变得复杂且耗时。为了简化这一过程,模拟(Mocking)技术应运而生。在 .NET 生态系统中,M..

CLS 问题:超过 0.1(桌面设备) 是什么意思?

在网页设计和开发中,CLS(Cumulative Layout Shift)是指页面布局的累计偏移量。当一个用户与页面互动时,如果页面的某些元素突然改变位置或大小,导致整个布局发生偏移,就会产生布局偏移。这种偏移可能会影响用户..

Angular UT 模拟执行setTimeout

在 Angular 单元测试中,我们经常需要模拟异步操作,比如 setTimeout。提高测试速度: 真实环境下的 setTimeout 会阻塞测试,导致测试运行时间过长。确保测试的可靠性: 模拟 setTimeout 可以让我们更好地控制异步操..

JavaScript 的 sessionStorage 能否加锁?

直接给 sessionStorage 加锁是不可能的。sessionStorage 的本质: sessionStorage 是浏览器提供的一种用于在当前浏览器会话中存储数据的机制。它存储在客户端,数据仅在当前浏览器窗口或标签页中有效。加锁的必要性..

Redis 同步、击穿、穿透及雪崩简述

对Redis最常见的几个问题,简要的说下我的理解与解决方法。数据同步指Redis做为缓存,在数据变化时,怎么保持与数据库数据同步的。一般解决方案为:缓存双删(同步方案大都采用删除缓存,而不会更新新缓存。缓存击穿..

Vue 3.5引入新特性 还有与SSR相关的改进

Vue 3.5引入了响应式属性解构、useTemplateRef方法、useId实用函数、内部响应性重构等新特性。以下是具体介绍:响应式属性解构此功能允许开发者在defineProps宏中解构属性而不会失去响应性,这为组件间的属性传递提..

发表回复

返回顶部