Git进阶使用(图文详解)

文章目录

  • 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
* masterfeature-branchbugfix-branch

在这里插入图片描述

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

2. 查看远程分支

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

git branch -r

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

$ git branch -rorigin/HEAD -> origin/mainorigin/mainorigin/feature-branchorigin/bugfix-branch

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

3. 查看本地和远程分支

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

git branch -a

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

$ git branch -a
* masterfeature-branchbugfix-branchremotes/origin/HEAD -> origin/mainremotes/origin/mainremotes/origin/feature-branchremotes/origin/bugfix-branch

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

4. 显示分支的详细信息

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

git branch -v

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

$ git branch -v
* master          a1b2c3d Initial commitfeature-branch  d4e5f6g Added new featurebugfix-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.rhkb.cn/news/355074.html

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

相关文章

2-11 基于matlab的BP-Adaboost的强分类器分类预测

基于matlab的BP-Adaboost的强分类器分类预测&#xff0c;Adaboost是一种迭代分类算法&#xff0c;其在同一训练集采用不同方法训练不同分类器&#xff08;弱分类器&#xff09;&#xff0c;并根据弱分类器的误差分配不同权重&#xff0c;然后将这些弱分类器组合成一个更强的最终…

第二十五篇——信息加密:韦小宝说谎的秘诀

目录 一、背景介绍二、思路&方案三、过程1.思维导图2.文章中经典的句子理解3.学习之后对于投资市场的理解4.通过这篇文章结合我知道的东西我能想到什么&#xff1f; 四、总结五、升华 一、背景介绍 加密这件事&#xff0c;对于这个时代的我们来说非常重要&#xff0c;那么…

Redis缓存的一些概念性问题

目录 缓存模型和思路 缓存更新策略 数据库和缓存不一致 缓存与数据库双写一致 缓存穿透 缓存雪崩 缓存击穿 速度快,好用&#xff0c;内存的读写性能远高于磁盘,缓存可以大大降低用户访问并发量带来的服务器读写压力 缓存模型和思路 标准的操作方式就是查询数据库之前先…

scratch编程03-反弹球

这篇文章和上一篇文章《scratch3编程02-使用克隆来编写小游戏》类似&#xff08;已经完全掌握了克隆的可以忽略这篇文章&#xff09;&#xff0c;两篇文章都使用到了克隆来编写一个小游戏&#xff0c;这篇文章与上篇文章不同的是&#xff0c;本体在进行克隆操作时&#xff0c;不…

Solr7.4.0报错org.apache.solr.common.SolrException

文章目录 org.apache.solr.common.SolrException: Exception writing document id MATERIAL-99598435990497269125316 to the index; possible analysis error: cannot change DocValues type from NUMERIC to SORTED_NUMERIC for field "opt_time"Exception writing…

账号和权限的管理

文章目录 管理用户账号和组账号用户账号的分类超级用户普通用户程序用户 UID&#xff08;用户id)和(组账号)GIDUID用户识别号GID组标识号 用户账号文件添加用户账号设置/更改用户口令 管理用户账号和组账号 用户账号的分类 超级用户 root 用户是 Linux 操作系统中默认的超级…

Python学习笔记15:进阶篇(四)文件的读写。

文件操作 学习编程操作中&#xff0c;我觉得文件操作是必不可少的一部分。不管是读书的时候学习的c&#xff0c;c&#xff0c;工作的前学的java&#xff0c;现在学的Python&#xff0c;没学过的php和go&#xff0c;都有文件操作的模块以及库的支持&#xff0c;重要性毫无疑问。…

HCIA-速查-ENSP模拟器2步清空配置

需求&#xff1a;清空模拟器配置 清空当前图中配置 步骤1&#xff1a;reset saved-configuration 后输入y确认 步骤2&#xff1a;reboot后输入n否认再输入y确认 验证已经清空配置

idea http client GET 请求 报503错误

idea 提供的 http client 插件&#xff0c;在 GET 请求时总是 报503 的错误&#xff0c;但请求URL可以在浏览器中正常访问。 GET localhost:8080/student Response file saved. > 2024-06-20T160906.503.html 有一种原因跟本地配置的代理有关&#xff0c;如下图。如果在…

基于JSP的高校信息资源共享平台

开头语&#xff1a; 你好呀&#xff0c;我是计算机学长猫哥&#xff01;如果你对高校信息资源共享平台感兴趣或者有相关需求&#xff0c;可以通过文末的联系方式找到我。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;JSP技术 工具&#xff1a;IDEA…

Java23种设计模式(五)

1、MVC 模式 MVC 模式代表 Model-View-Controller&#xff08;模型-视图-控制器&#xff09; 模式。这种模式用于应用程序的分层开发。 Model&#xff08;模型&#xff09; - 模型代表一个存取数据的对象或 JAVA POJO。它也可以带有逻辑&#xff0c;在数据变化时更新控制器。…

前缀和+双指针,CF 131F - Present to Mom

一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 131F - Present to Mom 二、解题报告 1、思路分析 很经典的一种把列看作cell 来进行双指针/递推的题型 我们考虑&#xff0c;可以预处理出原矩阵中的所有star 然后我们去枚举矩形的上下边界&#xff0c;把…

python:faces swap

# encoding: utf-8 # 版权所有 2024 涂聚文有限公司 # 许可信息查看&#xff1a;pip install boost # 描述&#xff1a;pip install boost # pip install dlib # pip install cmake3.25.2 # pip install dlib19.24.2 如果安装不上&#xff0c;按此法 # Author : geovindu,G…

【Go】用 DBeaver、db browser 和 SqlCipher 读取 SqlCipher 数据库

本文档主要描述如何用 DBeaver、db browser 和 SqlCipher 上打开加密的 SQLite3 数据库(用 SqlCipher v3 加密) 软件版本 DBeaver&#xff1a;v24.1.0 SQLite-driver: sqlite-jdbc-3.46.0.0.jar dbbrowser-for-sqlite-cipher&#xff1a;3.12.2 SqlCipher cli(ubuntun)&am…

基于Windows API DialogBox的对话框

在C中&#xff0c;DialogBox函数是Windows API的一部分&#xff0c;它用于在Win32应用程序中创建并显示一个模态对话框。DialogBox函数是USER32.DLL中的一个导出函数&#xff0c;因此你需要在你的C Win32应用程序中链接到这个库。 #include "framework.h" #include …

反转链表(java精简版)

反转一个单向链表。 public class ReversingLinkedList {static class Node {int val;Node next;public Node(int val) {this.val val;}public boolean hasNext() {return next ! null;}}public static void main(String[] args) {//构造Node head null;Node shift null;for…

大模型日报|8 篇必读的大模型论文

大家好&#xff0c;今日必读的大模型论文来啦&#xff01; 1.Pandora&#xff1a;自回归-扩散混合通用世界模型 世界模型模拟世界在不同行动下的未来状态&#xff0c;它们有助于创建交互式内容&#xff0c;并为有依据的长远推理提供基础。然而&#xff0c;目前的基础模型并不…

算法训练与程序竞赛题目集合(L2)

目录 L2-001 城市间紧急救援 输入格式: 输出格式: 输入样例: 输出样例: L2-002 链表去重 输入格式&#xff1a; 输出格式&#xff1a; 输入样例&#xff1a; 输出样例&#xff1a; L2-003 月饼 输入格式&#xff1a; 输出格式&#xff1a; 输入样例&#xff1a; …

【云岚到家】-day03-2-门户缓存实现实战

【云岚到家】-day03-2-门户缓存实现实战 5 缓存实现5.2 定时任务更新缓存5.2.1 分布式调度平台5.2.1.1 jdk提供的Timer定时器5.2.1.2 使用第三方Quartz方式5.2.1.3 使用分布式调度平台XXL-JOB 5.2.2 XXL-JOB5.2.2.1 介绍5.2.2.2 部署调度中心5.2.2.3 执行器 5.2.2 定义缓存更新…

如何在华为 Ascend 设备上运行模型

模型转换:使用华为的模型转换工具 ATC ATC 在 ascend-cann-toolkit 包里 环境 Docker Image: ascendhub.huawei.com/public-ascendhub/ascend-pytorch:24.0.RC1-A2-2.1.0-ubuntu20.04 镜像版本CANN版本Pytorch版本变更项24.0.RC18.0.RC12.1.0基础镜像变更为 ubuntu20.04。p…