Git分支与Git标签详解

这篇具有很好参考价值的文章主要介绍了Git分支与Git标签详解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

前言

一、Git分支(Branch)

1.分支的概念

2.分支的常用操作

3.Git 分支管理

二、Git标签(Tag)

1.标签的概念

2.标签的类型

3.标签的常用操作

4.Git标签管理


前言

        在软件开发过程中,版本管理是非常重要的一环。Git作为目前最流行的分布式版本控制系统之一,提供了丰富的功能来支持项目的版本管理。其中,分支(Branch)和标签(Tag)是Git中常用的两个概念,它们对于组织和管理代码的不同版本起着至关重要的作用。本篇博客将深入探讨Git分支和Git标签的概念、用法和最佳实践。

一、Git分支(Branch)

1.分支的概念

在Git中,分支是指指向提交对象(commit)的可变指针。它可以让开发者在不影响主线代码的情况下,独立地进行新功能的开发、问题的修复等工作。每个分支都包含着项目文件的一个完整副本,这意味着开发者可以在不同的分支上同时进行不同的工作,而不会相互影响。

2.分支的常用操作

  • 创建分支:git branch <branch_name>
  • 切换分支:git checkout <branch_name> 或 git switch <branch_name>
  • 合并分支:git merge <branch_name>
  • 删除分支:git branch -d <branch_name>

3.Git 分支管理

列出分支

列出分支基本命令:

git branch

没有参数时,git branch 会列出你在本地的分支。

$ git branch
* master

此例的意思就是,我们有一个叫做 master 的分支,并且该分支是当前分支。

当你执行 git init 的时候,默认情况下 Git 就会为你创建 master 分支。

github 标签和分支,Git,git,运维

创建并切换分支:你可以创建一个新的分支,这个分支是从当前工作目录的状态创建的,包含了当前工作目录中的所有文件和文件夹。 

github 标签和分支,Git,git,运维

如果我们要手动创建一个分支。执行 git branch (branchname) 即可。

$ git branch testing
$ git branch
* master
  testing

现在我们可以看到,有了一个新分支 testing

当你以此方式在上次提交更新之后创建了新分支,如果后来又有更新提交, 然后又切换到了 testing 分支,Git 将还原你的工作目录到你创建分支时候的样子。

接下来我们将演示如何切换分支,我们用 git checkout (branch) 切换到我们要修改的分支。

$ ls
README
$ echo 'ctb.com' > test.txt
$ git add .
$ git commit -m 'add test.txt'
[master 3e92c19] add test.txt
 1 file changed, 1 insertion(+)
 create mode 100644 test.txt
$ ls
README        test.txt
$ git checkout testing
Switched to branch 'testing'
$ ls
README

当我们切换到 testing 分支的时候,我们添加的新文件 test.txt 被移除了。切换回 master 分支的时候,它们又重新出现了。

$ git checkout master
Switched to branch 'master'
$ ls
README        test.txt

我们也可以使用 git checkout -b (branchname) 命令来创建新分支并立即切换到该分支下,从而在该分支中操作。

$ git checkout -b newtest
Switched to a new branch 'newtest'
$ git rm test.txt 
rm 'test.txt'
$ ls
README
$ touch ctb.java
$ git add .
$ git commit -am 'removed test.txt、add ctb.java'
[newtest c1501a2] removed test.txt、add ctb.java
 2 files changed, 1 deletion(-)
 create mode 100644 ctb.java
 delete mode 100644 test.txt
$ ls
README        ctb.java
$ git checkout master
Switched to branch 'master'
$ ls
README        test.txt

如你所见,我们创建了一个分支,在该分支上移除了一些文件 test.txt,并添加了 ctb.java 文件,然后切换回我们的主分支,删除的 test.txt 文件又回来了,且新增加的 ctb.java不存在主分支中。

使用分支将工作切分开来,从而让我们能够在不同开发环境中做事,并来回切换。

删除分支

删除分支命令:

git branch -d (branchname)

例如我们要删除 testing 分支:

$ git branch
* master
  testing
$ git branch -d testing
Deleted branch testing (was 85fc7e7).
$ git branch
* master

分支合并

一旦某分支有了独立内容,你终究会希望将它合并回到你的主分支。 你可以使用以下命令将任何分支合并到当前分支中去:

git merge
$ git branch
* master
  newtest
$ ls
README        test.txt
$ git merge newtest
Updating 3e92c19..c1501a2
Fast-forward
 ctb.java | 0
 test.txt   | 1 -
 2 files changed, 1 deletion(-)
 create mode 100644 ctb.java
 delete mode 100644 test.txt
$ ls
README        ctb.java

以上实例中我们将 newtest 分支合并到主分支去,test.txt 文件被删除。

合并完后就可以删除分支:

$ git branch -d newtest
Deleted branch newtest (was c1501a2).

删除后, 就只剩下 master 分支了:

$ git branch
* master

合并冲突

合并并不仅仅是简单的文件添加、移除的操作,Git 也会合并修改。

$ git branch
* master
$ cat ctb.java

首先,我们创建一个叫做 change_site 的分支,切换过去,我们将 ctb.java 内容改为:

pubic class ctb(){
}

创建 change_site 分支:

$ git checkout -b change_site
Switched to a new branch 'change_site'
$ vim ctb.java
$ head -3 ctb.java
pubic class ctb(){
}
$ git commit -am 'changed the ctb.java'
[change_site 7774248] changed the ctb.java
 1 file changed, 3 insertions(+)

将修改的内容提交到 change_site 分支中。 现在,假如切换回 master 分支我们可以看内容恢复到我们修改前的(空文件,没有代码),我们再次修改 ctb.java文件。

$ git checkout master
Switched to branch 'master'
$ cat ctb.java
$ vim ctb.java    # 修改内容如下
$ cat ctb.java
<?php
echo 1;
?>
$ git diff
diff --git a/ctb.java b/ctb.java
index e69de29..ac60739 100644
--- a/ctb.java
+++ b/ctb.java
@@ -0,0 +1,3 @@
+<?php
+echo 1;
+?>
$ git commit -am '修改代码'
[master c68142b] 修改代码
 1 file changed, 3 insertions(+)

现在这些改变已经记录到我的 "master" 分支了。接下来我们将 "change_site" 分支合并过来。

$ git merge change_site
Auto-merging ctb.java
CONFLICT (content): Merge conflict in ctb.java
Automatic merge failed; fix conflicts and then commit the result.

$ cat ctb.java     # 打开文件,看到冲突内容
<?php
<<<<<<< HEAD
echo 1;
=======
echo 'ctb';
>>>>>>> change_site
?>

我们将前一个分支合并到 master 分支,一个合并冲突就出现了,接下来我们需要手动去修改它。

$ vim ctb.java
$ cat ctb.java
<?php
echo 1;
echo 'ctb';
?>
$ git diff
diff --cc ctb.java
index ac60739,b63d7d7..0000000
--- a/ctb.java
+++ b/ctb.java
@@@ -1,3 -1,3 +1,4 @@@
  <?php
 +echo 1;
+ echo 'ctb';
  ?>

在 Git 中,我们可以用 git add 要告诉 Git 文件冲突已经解决

$ git status -s
UU ctb.java
$ git add ctb.java
$ git status -s
M  ctb.java
$ git commit
[master 88afe0e] Merge branch 'change_site'

现在我们成功解决了合并中的冲突,并提交了结果。

二、Git标签(Tag)

1.标签的概念

在Git中,标签是一个指向特定提交对象的指针,通常用于标识版本发布、里程碑等重要事件。标签可以帮助开发者和用户快速定位和回溯不同的版本,也可以作为项目中重要版本的标记。

2.标签的类型

  • 轻量标签(Lightweight tag):只是简单地指向某个提交对象,类似于分支,不具备其他元数据。
  • 注解标签(Annotated tag):除了指向某个提交对象外,还包含标签的创建者、创建日期、注释等信息。

3.标签的常用操作

  • 创建轻量标签:git tag <tag_name>
  • 创建注解标签:git tag -a <tag_name> -m "tag message"
  • 查看标签列表:git tag
  • 删除标签:git tag -d <tag_name>

4.Git标签管理

Git 使用的标签有两种类型:轻量级的(lightweight)含附注的(annotated)

轻量级标签就像是个不会变化的分支,实际上它就是个指向特定提交对象的引用。

而含附注标签,实际上是存储在仓库中的一个独立对象,它有自身的校验和信息,包含着标签的名字,电子邮件地址和日期,以及标签说明,标签本身也允许使用 GNU Privacy Guard (GPG) 来签署或验证。

一般我们都建议使用含附注型的标签,以便保留相关信息;

当然,如果只是临时性加注标签,或者不需要旁注额外信息,用轻量级标签也没问题。

创建标签

[root@Git git]# git tag v1.0

查看已有标签

[root@Git git]# git tag
v1.0
[root@Git git]# git tag v1.1
[root@Git git]# git tag
v1.0
v1.1

删除标签

[root@Git git]# git tag -d v1.1
Deleted tag ‘v1.1’ (was 91388f0)
[root@Git git]# git tag
v1.0

查看此版本所修改的内容

[root@Git git]# git show v1.0
commit 91388f0883903ac9014e006611944f6688170ef4
Author: "syaving" <"819044347@qq.com">
Date: Fri Dec 16 02:32:05 2016 +0800
commit dir
diff –git a/readme b/readme
index 7a3d711..bfecb47 100644
— a/readme
+++ b/readme
@@ -1,2 +1,3 @@
text
hello git
+use commit
[root@Git git]# git log –oneline
91388f0 commit dir
e435fe8 add readme
2525062 add readme

推送标签到远程仓库:

使用以上命令将本地的标签推送到名为 origin 的远程仓库。

  • 单个标签推送:git push origin <tag_name>
  • 所有标签推送:git push origin --tags

拉取远程仓库的标签:文章来源地址https://www.toymoban.com/news/detail-752018.html

  • 拉取所有标签:git fetch origin <tag_name>
  • git pull origin <tag_name>

到了这里,关于Git分支与Git标签详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • git 创建标签 推送到远程分支上

    要在Git中创建标签并将其推送到远程dev分支,可以按照以下步骤操作: 1、首先,确保你已经在本地的Git仓库中,并且切换到dev分支。 2、创建标签并给予其一个有描述性的名称。你可以使用以下命令创建一个轻量级标签: 例如: 或者,你可以创建一个带有附注的标签,其中

    2024年02月15日
    浏览(76)
  • git下载指定标签分支命令(挺好用的)

    使用 --single-branch 开关 (从Git 1.7.10开始) 。 语法是: git clone -b tag_name --single-branch repo_url [dest_dir] 例如: git clone -b ‘2.1.1’ --single-branch https://gitee.com/xuxueli0323/xxl-job.git 好处: Git将只接收对象并(需要)只为指定的分支/标签parsing变化量 – 同时检出相同数量的文件! 根据

    2024年02月12日
    浏览(41)
  • 【Git】Git分支与标签掌握这些技巧让你成为合格的码农

    🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是Java方文山,一个在CSDN分享笔记的博主。📚📚 🌟推荐给大家我的专栏《Git》。🎯🎯 👉点击这里,就可以查看我的主页啦!👇👇 Java方文山的个人主页 🎁如果感觉还不错的话请给我点赞吧!🎁🎁 💖期待你的加入,一起学习,

    2024年02月05日
    浏览(37)
  • Git的核心概念:探索Git中的提交、分支、合并、标签等核心概念,深入理解其作用和使用方法

    🌷🍁 博主 libin9iOak带您 Go to New World.✨🍁 🦄 个人主页——libin9iOak的博客🎐 🐳 《面试题大全》 文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺 🌊 《IDEA开发秘籍》学会IDEA常用操作,工作效率翻倍~💐 🪁🍁 希望本文能够给您带来一定的帮助🌸文章粗浅,敬

    2024年02月16日
    浏览(38)
  • git的本地分支如何关联远程分支,比如github,gitlab,码云等

    今天发布某版本的项目,准备创建个 v0point1 分支,后期如果修改该版本,直接在该分支上修改即可。 首先,使用 git branch v0point1 命令,创建本地分支 v0point1 ,如下图所示: 其次,使用 git checkout v0point1 命令,切换到 v0point1 分支,如下图所示: 当然,我们也可以使用 git ch

    2024年02月13日
    浏览(53)
  • 【Git】Github fork项目后如何拉取其他分支

    【前言】我们在Github里fork了一个仓库后会发现自己的仓库里只有一个分支,就是源仓库的主分支,这个时候我们想在其他分支上贡献代码,应该怎么办呢?因为有时候我们可能会想把修改同步到多个分支。 查看当前分支: 该仓库的主分支为release/2.6,此时我已经切换到了d

    2024年02月15日
    浏览(41)
  • Git 概述、命令、分支,免密登录;及 Idea 集成 GitHub

    Git 概述 Git 是一个免费的、开源的 分布式版本控制系统 ,可以快速高效地处理从小型到大型的各种项目 Git 易于学习,占地面积小,性能极快。它具有廉价的本地库,方便的暂存区域和多个工作流分支等特性。其性能优于 Subversion、CVS、Perforce 和 ClearCase 等版本控制工具 集中

    2024年02月07日
    浏览(31)
  • 【运维知识高级篇】一篇文章带你搞懂Git!(Git安装+全局配置+Git初始化代码仓库+Git四大区域+Git四种状态+Git常用命令+Git分支+Git测试代码回滚)

    版本流程控制系统(version control system)是一种记录一个或若干个文件内容变化,以便将来查阅特定版本内容情况的系统,它会记录文件的所有历史变化,我们可以随时恢复到任何一个历史状态,同时支持多人协作开发。 目录 常见的版本管理工具 Git安装与全局配置 Git初始化

    2024年02月02日
    浏览(37)
  • Git使用详解(图文+代码):Git分支

    每一种版本控制都以某种形式支持分支。 使用分支的好处就是你可以从开发主线上分离开来,在不影响主线的同时继续工作。 在之前的版本控制系统中,这个是奢侈昂贵的操作,经常需要创建一个源代码目录的完整副本,对大型项目来说花费大量时间。 有了Git分支模型,将

    2024年01月18日
    浏览(24)
  • 使用Git Bash拉取github仓库代码(包含分支拉取与切换)

    小白记录一下自己拉取项目的过程 1. 创建一个文件夹,用来存放使用git克隆下来的代码。 2.在此右键打开Git Bash Here。 3.对项目进行克隆,项目地址为github仓库中Code下复制的HTTPS地址。期间可能需要进行身份验证。此时下载了仓库中的master,并创建了本地分支main,且本地分支

    2024年02月16日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包