Git进阶使用(图文详解)

news2025/2/28 15:41:31

文章目录

  • Git概述
  • Git基础指令
  • Git进阶使用
    • 一、Git分支
    • 1.主干分支
    • 2.其他分支
      • 2.1创建分支
      • 2.2查看分支
        • 1. 查看本地分支
        • 2. 查看远程分支
        • 3. 查看本地和远程分支
        • 4. 显示分支的详细信息
        • 5. 查看已合并和未合并的分支
      • 2.3切换分支
        • 1. 切换到已有的本地分支
        • 2. 创建并切换到新分支
        • 3. 切换到远程分支
        • 4. 切换到上一个分支
        • 注意事项
      • 2.4删除分支
    • 二、Git合并
    • 三、Git冲突
      • 1. 创建初始仓库和文件
      • 2. 创建分支 B1 并进行修改
      • 3. 创建分支 B2 并进行修改
      • 4. 合并 B2 到 master 分支 (预期无冲突)
      • 5. 合并 B1 到 master 分支 (预期有冲突)
      • 6. 解决冲突
      • 7. 标记冲突已解决并完成合并
      • 8. 查看合并结果


Git概述

Git基础指令

Git进阶使用

一、Git分支

  • 在 Git 中,分支允许你在同一个代码库中同时进行不同的工作,而不会相互干扰。

  • 每个分支都代表了代码库的一个独立线索,可以用来开发新功能、修复 bug、修改配置文件等,而不会影响其他分支的内容。

  • 使用分支可以很好地解决环境配置文件不同的问题。

  • 可以创建不同的分支来管理本地环境和服务器环境的配置文件,这样就可以根据需要在不同的分支上进行修改,而不必担心冲突或混淆。

  • 分支感觉上就是树上的分叉一样,会按照不同的路线生长下去。有可能以后不再相交,当然,也可能以后会不断地纠缠下去,都是有可能的。
    在这里插入图片描述

1.主干分支

  • 默认情况下,Git 仓库在初始化时会创建一个名为master的分支,这是 Git 的默认主分支。
    在这里插入图片描述

  • 这个分支通常被认为是代码库的主干,所有稳定和经过测试的代码通常都会合并到这个分支。

  • 所有的操作如果不显式地切换到其他分支,都会在这个默认分支上进行。

需要注意的是,近年来 Git 和许多软件项目开始将默认分支名称从 master 改为 main,以避免可能的歧义和历史包袱。如果你使用较新的 Git 版本或某些托管服务(如 GitHub),初始化仓库时默认分支名称可能是 main 而不是 master。

2.其他分支

如果仅仅是一个分支,在某些情况并不能满足实际的需求,那么就需要创建多个不同的分支。

2.1创建分支

  • git branch 分支名称
git branch b1
git branch b2

现在我们创建了2个分支,不过这两个分支都是基于master主干分支为基础的。
在这里插入图片描述

2.2查看分支

1. 查看本地分支

要查看当前仓库中的所有本地分支,可以使用以下命令:

git branch

这个命令会列出所有本地分支,并且会用 * 标记当前所在的分支。

$ git branch
* master
  feature-branch
  bugfix-branch

在这里插入图片描述

在这个输出中,master 是当前所在的分支。

2. 查看远程分支

如果你想查看远程仓库中的所有分支,可以使用以下命令:

git branch -r

这个命令会列出所有远程分支。

$ git branch -r
  origin/HEAD -> origin/main
  origin/main
  origin/feature-branch
  origin/bugfix-branch

这里 origin 是默认的远程仓库名称,可以看到远程仓库中的分支列表。

3. 查看本地和远程分支

同时查看本地和远程的所有分支,可以使用以下命令:

git branch -a

这个命令会列出本地和远程的所有分支。例如:

$ git branch -a
* master
  feature-branch
  bugfix-branch
  remotes/origin/HEAD -> origin/main
  remotes/origin/main
  remotes/origin/feature-branch
  remotes/origin/bugfix-branch

在这个输出中,本地分支和远程分支会分别列出,其中远程分支前面带有 remotes/ 前缀。

4. 显示分支的详细信息

如果你想查看分支的更多详细信息,比如每个分支的最后一次提交,可以使用以下命令:

git branch -v

这个命令会列出每个分支的名称及其最近的一次提交信息。

$ git branch -v
* master          a1b2c3d Initial commit
  feature-branch  d4e5f6g Added new feature
  bugfix-branch   g7h8i9j Fixed a bug

在这里插入图片描述

5. 查看已合并和未合并的分支
  • 查看已经合并到当前分支的所有分支.

    git branch --merged
    
  • 查看尚未合并到当前分支的所有分支。

    git branch --no-merged
    

2.3切换分支

1. 切换到已有的本地分支

要切换到一个已经存在的本地分支,可以使用以下命令:

git checkout <branch-name>

将工作线路切换到b1

# git checkout 分支名称
git checkout b1

在这里插入图片描述

添加新的文件b1.txt,然后提交到版本库。
在这里插入图片描述
在这里插入图片描述

查看分支信息,会发现不同分支的版本进度信息发生了改变

在这里插入图片描述
此时切换回到主干分支的话,那么b1.txt文件就不存在了,因为对应版本信息不一样。

在这里插入图片描述
在这里插入图片描述

2. 创建并切换到新分支

创建一个新的分支并立即切换到该分支

git checkout -b <new-branch-name>

在这里插入图片描述

3. 切换到远程分支

远程分支是位于远程仓库中的分支,切换到一个还没有在本地存在但在远程仓库中存在的分支,需要先将其拉取到本地,然后再切换。

  1. 使用 git fetch 命令更新远程仓库信息:

    git fetch
    
  2. 使用以下命令创建一个新的本地分支并追踪相应的远程分支:

    git checkout -b <new-branch-name> origin/<remote-branch-name>
    

创建并切换到一个名为 remote-feature 的远程分支

git checkout -b remote-feature origin/remote-feature
4. 切换到上一个分支

Git 提供了一种方便的方法来快速切换回你之前的分支,可以使用 - 选项:

git checkout -

这个命令会切换到你上一次所在的分支。例如,如果你从 master 分支切换到 feature-branch 分支,然后想要快速切换回 master 分支,可以简单地执行:

在这里插入图片描述

注意事项
  1. 未提交的更改:在切换分支前,确保你在当前分支上的未提交更改不会丢失。你可以通过以下方式处理:

    • 提交未提交的更改。

    • 将未提交的更改暂存到 stash 中:

      git stash
      

    然后在新分支上恢复:

    git stash apply
    
  2. 冲突:如果你在切换分支时遇到冲突,Git 会提示你解决冲突。你需要手动解决冲突并提交解决冲突后的结果。


2.4删除分支

某一个分支建立的不太理想或已经没有必要在使用了,那么是可以将这个分支删除的。

git branch -d 分支名称

在这里插入图片描述

在这里插入图片描述


二、Git合并

  • 在软件开发中,通常会创建多个分支来同时进行不同的工作,比如修复 bug、开发新功能、进行实验性的工作等等。每个分支都代表了一个特定的工作环境和目标。

  • 然而,最终目标是将这些分支合并到主要的代码库中,形成项目的最终结果。这通常通过合并分支或者重新基于最新代码进行开发来实现。

在这里插入图片描述

将b3分支的文件内容合并到主干分支中。

首先先切换回主干分支
在这里插入图片描述
在这里插入图片描述

创建b3分支,并直接切换到新的分支

在这里插入图片描述
在这里插入图片描述

在新的分支中添加新文件b3.txt

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

此时切换回主干分支,只有yushifu.txt文件。

在这里插入图片描述

我们将b3分支的文件内容合并到主干分支中。

首先先切换回主干分支
在这里插入图片描述

执行分支合并指令

# git merge 分支名称
git merge new_branch

在这里插入图片描述
此时再次查看文件,就会发现b3.txt文件已经可以看到了。


三、Git冲突

  • 在多分支并行处理时,每一个分支可能是基于不同版本的主干分支创建的。
  • 如果每隔分支都独立运行而不进行合并,就没有问题,但是如果在后续操作过程中进行合并的话,就有可能产生冲突。
  • 比如B1, B2的两个分支都是基于master分支创建出来的。B1分支如果和B2分支修改了同一份文件的话,那么在合并时,以哪一个文件为准呢,这就是所谓的冲突。

在这里插入图片描述

可以通过一个具体的例子来展示如何处理 Git 合并冲突。

假设我们有一个 README.md 文件,并且我们有两个分支 B1B2,它们都是基于 master 分支创建的。在这些分支中,我们对 README.md 进行了不同的修改。

1. 创建初始仓库和文件

# 初始化一个新的Git仓库
git init example-repo
cd example-repo

# 创建 README.md 文件
echo "This is the master branch" > README.md

# 添加并提交
git add README.md
git commit -m "Initial commit on master"

2. 创建分支 B1 并进行修改

# 创建 B1 分支
git checkout -b B1

# 修改 README.md 文件
echo "Change made in B1 branch" >> README.md

# 添加并提交
git add README.md
git commit -m "Update README.md in B1"

3. 创建分支 B2 并进行修改

# 切换回 master 分支
git checkout master

# 创建 B2 分支
git checkout -b B2

# 修改 README.md 文件
echo "Change made in B2 branch" >> README.md

# 添加并提交
git add README.md
git commit -m "Update README.md in B2"

4. 合并 B2 到 master 分支 (预期无冲突)

# 切换回 master 分支
git checkout master

# 合并 B2 分支
git merge B2
# 没有冲突,合并成功

5. 合并 B1 到 master 分支 (预期有冲突)

# 合并 B1 分支
git merge B1
# 这时会产生冲突,因为 README.md 文件在 B1 和 B2 分支中都被修改了

在这里插入图片描述

6. 解决冲突

现在我们查看 README.md 文件,会看到如下内容:

This is the master branch
<<<<<<< HEAD
Change made in B2 branch
=======
Change made in B1 branch
>>>>>>> B1

在这里插入图片描述

这里的冲突,软件是无法判断该如何出来处理的,所以需要人工进行判断,将冲突的文件内容进行修正。

假设我们希望保留两处修改,可以将文件编辑成如下内容:

This is the master branch
Change made in B2 branch
Change made in B1 branch

7. 标记冲突已解决并完成合并

# 标记 README.md 为已解决
git add README.md

# 完成合并
git commit -m "Merge B1 branch and resolve conflict"

8. 查看合并结果

现在查看 README.md 文件,确认合并后的内容:

This is the master branch
Change made in B2 branch
Change made in B1 branch

在这里插入图片描述


本文仅供学习使用!

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MyPostMan:按照项目管理接口,基于迭代生成接口文档、执行接口自动化联合测试

MyPostMan 是一款类似 PostMan 的接口请求软件&#xff0c;不同于 PostMan 的是&#xff0c;它按照 项目&#xff08;微服务&#xff09;、目录来管理我们的接口&#xff0c;基于迭代来管理我们的接口文档&#xff0c;按照迭代编写自动化测试用例&#xff0c;在不同环境中均可运…

ASP.NET MVC企业级程序设计(增删,页面水平排列,字符串拼接,非空,添加框内默认提示)

目录 题目&#xff1a; 实现过程 控制器代码 DAL BLL Index Deile 题目&#xff1a; 实现过程 控制器代码 using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; using MvcApplication1.Models;namespac…

oracle中执行select ... for update需要什么权限?

oracle中执行select … for update需要什么权限&#xff1f; 问题 在oracle中&#xff0c;一个用户执行select … for update需要什么权限&#xff1f; 分析测试 用户1&#xff1a; test_0614 用户2&#xff1a;test 目标表&#xff1a;test.t_0614 执行语句&#xff1a;se…

机器学习课程复习

参考书目:《统计学习方法》 选择题 5道 3分/道 填空题 5道 3分/道 简答题 3道 计算题 1道 算法设计题 1道 隐马尔可夫不考计算题 很有可能考计算题的知识点:KNN、决策树、支持向量机、聚类算法 小概率会考计算题的知识点:线性回归(最小二乘法,代公式算参…

代码随想录——全排列(Leetcode LCR083)

题目链接 回溯 class Solution {List<List<Integer>> res new ArrayList<List<Integer>>();List<Integer> list new ArrayList<Integer>();boolean[] used;public List<List<Integer>> permute(int[] nums) {used new bo…

密码学及其应用——为什么选择接近的质数因子对RSA加密算法不安全?

RSA加密算法是一种广泛使用的非对称加密算法&#xff0c;它的安全性依赖于大整数分解的难度。具体来说&#xff0c;RSA算法生成的公钥包含一个大整数N&#xff0c;这是两个大质数p和q的乘积。然而&#xff0c;如果这两个质数p和q太接近&#xff0c;则可以相对容易地对N进行因式…

【Python机器学习实战】 | Lasso回归和弹性网回归详细分析研究

&#x1f3a9; 欢迎来到技术探索的奇幻世界&#x1f468;‍&#x1f4bb; &#x1f4dc; 个人主页&#xff1a;一伦明悦-CSDN博客 ✍&#x1f3fb; 作者简介&#xff1a; C软件开发、Python机器学习爱好者 &#x1f5e3;️ 互动与支持&#xff1a;&#x1f4ac;评论 &…

【STM32】矩阵计算器

【STM32】矩阵计算器 资料链接请在文章末尾获取~ 1.说明 使用元器件&#xff1a;stm32f103c8t6最小系统板x1&#xff0c;0.96寸OLED显示屏四角x1&#xff0c;4x4矩阵按键x1; 参考&#xff1a;正点原子有关4脚OLED驱动float型数据的驱动文件&#xff0c;CSDN有关矩阵横向扫描…

网络安全:入侵检测系统的原理与应用

文章目录 网络安全&#xff1a;入侵检测系统的原理与应用引言入侵检测系统简介IDS的工作原理IDS的重要性结语 网络安全&#xff1a;入侵检测系统的原理与应用 引言 在我们的网络安全系列文章中&#xff0c;我们已经涵盖了从SQL注入到端点保护的多个主题。本篇文章将探讨入侵检…

八大排序————C语言版实现

Hello&#xff0c;各位未来的高级程序员们&#xff0c;大家好&#xff0c;今天我就来为大家讲解一下有关排序的内容&#xff0c;我们常见的排序就是我们接下来要讲的这八个排序&#xff0c;我们平常所说的排序有十大排序&#xff0c;我们这里的八大排序是我们生活中最为常见的八…

【机器学习】:线性回归模型学习路线

Hi~&#xff01;这里是奋斗的小羊&#xff0c;很荣幸您能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎 ~~ &#x1f4a5;&#x1f4a5;个人主页&#xff1a;奋斗的小羊 &#x1f4a5;&#x1f4a5;所属专栏&#xff1a;C语言 &#x1f680;本系列文章为个人学习…

探究布局模型:从LayoutLM到LayoutLMv2与LayoutXLM

LAYOUT LM 联合建模文档的layout信息和text信息&#xff0c; 预训练 文档理解模型。 模型架构 使用BERT作为backbone&#xff0c; 加入2-D绝对位置信息&#xff0c;图像信息 &#xff0c;分别捕获token在文档中的相对位置以及字体、文字方向、颜色等视觉信息。 2D位置嵌入 …

DOPE-FITC在细胞定位、动态追踪等方面的应用-星戈瑞

DOPE-FITC作为一种荧光标记磷脂&#xff0c;在细胞生物学研究中发挥着科研作用。其荧光特性和与细胞膜的亲和性&#xff0c;使其成为细胞定位、动态追踪等方面的工具。 细胞定位 DOPE-FITC能够有效地标记细胞膜&#xff0c;使得细胞膜在荧光显微镜下呈现出明亮的绿色荧光。这种…

NLP入门——复杂函数建模与链式求导

复杂函数建模 前面我们研究的梯度下降法分类&#xff0c;是简单的对每类中每个子词的分数进行求和&#xff0c;统计分数最大的类别并不断调整分数来提高准确率。 我们可以修改函数模型&#xff0c;用更加复杂的函数代替sum()&#xff0c;来达到更好的学习效果。 def compute_…

LLM大语言模型应用方案之RAG检索增强生成的实现步骤。

0.我理解的RAG 什么是RAG&#xff1f; RAG的全称是“检索增强生成模型”&#xff08;Retrieval-Augmented Generation&#xff09;。这是一种特别聪明的大语言模型。 RAG是怎么工作的呢&#xff1f; 1.检索&#xff1a;当你问RAG一个问题时&#xff0c;它会先去“图书…

Dockerfile封装制作pytorch(tensorflow)深度学习框架 + jupyterlab服务 + ssh服务镜像

一&#xff1a;docker-hub官网寻找需求镜像 1.我们在https://hub.docker.com/官网找到要封装的pytorch基础镜像&#xff0c;这里我们以pytorch1.13.1版本为例 2.我们找到的这个devel版本的镜像&#xff08;我们需要cuda的编译工具&#xff09; pytorch版本是1.13.1&#xff0c;…

Windows桌面运维----第四天

1、U盘故障打不开&#xff1a; 操作方式&#xff1a;WinR打开运行&#xff0c;输入cmd确定&#xff0c;在&#xff08;C:\Users\Administrator>&#xff09;后输入chkdsk,空格&#xff0c;输入U盘盘符&#xff0c;例如F:/F&#xff0c;回车&#xff0c;等待修复完成。 2、…

Bad return type in lambda expression: void cannot be converted to Unit

1.背景 当kotlin中声明需要传入一个返回值为空(Unit)的方法引用. 代码示例: 下方第二个参数为一个方法引用,(参数为BiometricPrompt.AuthenticationResult, 返回类型为Unit). object BiometricPromptUtil {private const val TAG "BiometricPromptUtil"fun cre…

Day6—热点搜索词统计

一、要求 根据用户上网的搜索记录对每天的热点搜索词进行统计&#xff0c;以了解用户所关心的热点话题。 要求完成&#xff1a;统计每天搜索数量前3名的搜索词&#xff08;同一天中同一用户多次搜索同一个搜索词视为1次&#xff09;。 二、数据 三、配置scala环境 1.下载sca…

思科PAP命令笔记

命令格式 含义 版权声明&#xff1a;本文为博主原创文章&#xff0c;遵循 CC 4.0 BY-SA 版权协议&#xff0c;转载请附上原文出处链接和本声明。 原文链接&#xff1a;https://blog.csdn.net/qq_44862120/article/details/115675197 ——————…