《Git 简易速速上手小册》第2章:理解版本控制(2024 最新版)

在这里插入图片描述

文章目录

  • 2.1 本地仓库与版本历史
    • 2.1.1 基础知识讲解
    • 2.1.2 重点案例:回滚错误提交
    • 2.1.3 拓展案例 1:利用 `git bisect` 查找引入 bug 的提交
    • 2.1.4 拓展案例 2:合并提交历史
  • 2.2 远程仓库的使用
    • 2.2.1 基础知识讲解
    • 2.2.2 重点案例:在 GitHub 上协作
    • 2.2.3 拓展案例 1:处理合并冲突
    • 2.2.4 拓展案例 2:利用 Pull Request 进行代码审查
  • 2.3 版本回退与冲突解决
    • 2.3.1 基础知识讲解
    • 2.3.2 重点案例:修复一个破坏性的提交
    • 2.3.3 拓展案例 1:合并时解决冲突
    • 2.3.4 拓展案例 2:使用 `git rebase` 保持清洁的提交历史

2.1 本地仓库与版本历史

深入 Git 的世界,掌握本地仓库和版本历史的管理是每个开发者的必修课。本地仓库让你的项目历史和所有变更都在你的掌控之中,而版本历史则是你项目的时间线,记录了从初始提交到最新更改的每一个步骤。

2.1.1 基础知识讲解

  • 本地仓库:是你项目的心脏,存储着代码的所有版本。每次执行 git commit 命令,Git 都会将当前暂存区的快照作为一个新的提交保存到仓库中。
  • 版本历史:通过 git log 命令查看,它详细记录了每次提交的作者、日期和提交信息,让你可以追溯每一次更改的来龙去脉。
  • 查看更改git diff 命令允许你查看自上次提交以来你的代码发生了哪些更改,而 git show [commit] 可以查看特定提交的详细更改。

2.1.2 重点案例:回滚错误提交

假设你正在开发一个 Python 应用,你刚刚完成了一个新功能的开发,并且进行了提交。但突然间,你意识到这个提交引入了一个严重的错误。别担心,Git 能够帮你轻松回到错误发生之前。

# 查看提交历史,找到你想回到的那个提交的哈希值
git log
# 假设你想回到的提交哈希值是 abc1234
git checkout abc1234
# 创建一个新的分支来修复这个错误
git checkout -b fix-the-bug

在这个分支上,你可以放心地修复错误,而不会影响主分支。

2.1.3 拓展案例 1:利用 git bisect 查找引入 bug 的提交

当你面对一个神秘的 bug,而且不确定它是在哪个提交中被引入的时候,git bisect 可以成为你的侦探工具。通过在好的(没有 bug)和坏的(有 bug)提交之间进行二分查找,Git 可以帮助你快速定位问题的来源。

git bisect start
git bisect bad                 # 当前版本有 bug
git bisect good abc1234        # abc1234 版本是好的
# Git 会自动检出一半的提交供你测试,直到找到第一个引入 bug 的提交
git bisect reset               # 结束 bisect 会话

2.1.4 拓展案例 2:合并提交历史

如果你的提交历史变得杂乱无章,你可能想要通过合并一些提交来清理它。git rebase 是一个强大的工具,允许你修改、合并或者重新排序提交。

git rebase -i HEAD~5

这个命令会打开一个交互式界面,列出了最近的 5 次提交,你可以选择哪些提交需要被合并(squash)、重写(reword)或者重新排序。

通过这一章,你已经学会了如何有效地管理你的本地仓库和版本历史,以及如何在出现问题时优雅地恢复。记住,每个错误都是一个学习的机会,Git 则是你在这个过程中的最佳伙伴。现在,让我们继续前进,探索更多 Git 的奥秘吧!

在这里插入图片描述


2.2 远程仓库的使用

远程仓库,这个神奇的概念,让我们的代码不再孤单。它允许我们与世界分享我们的成果,同时也能从他人那里获得灵感和帮助。不论是 GitHub、GitLab 还是 Bitbucket,这些平台都成为了我们展示和协作项目的舞台。

2.2.1 基础知识讲解

  • 远程仓库的概念:远程仓库是位于互联网或网络上的仓库,可以通过 URL 访问。它让多个开发者能够共享一个项目并协同工作。
  • 添加远程仓库:使用 git remote add origin [URL] 命令,你可以添加一个新的远程仓库。origin 是远程仓库的默认名字,但你可以根据需要命名为其他。
  • 推送(Push)git push 命令让你能将本地的更改推送到远程仓库。这是分享你的更改给其他人的主要方式。
  • 拉取(Pull)git pull 命令用于从远程仓库获取最新的更改并合并到你的本地仓库。它是获取其他人更改的主要方式。

2.2.2 重点案例:在 GitHub 上协作

假设你正在与你的团队在 GitHub 上协作开发一个 Python 项目。项目的目标是创建一个简单的网页爬虫。

步骤 1:克隆远程仓库

首先,你需要将项目克隆到你的本地机器上:

git clone https://github.com/yourteam/python-web-crawler.git

这会在你的本地创建一个项目的副本,并自动添加远程仓库 origin 指向该 GitHub 仓库。

步骤 2:添加新功能

你决定添加一个新的功能:解析网页的标题。你在本地创建了一个新分支,开发了这个功能,并准备将它推送到 GitHub。

# parse_title.py
import requests
from bs4 import BeautifulSoupdef parse_title(url):response = requests.get(url)soup = BeautifulSoup(response.text, 'html.parser')return soup.title.text

步骤 3:推送更改

在完成新功能后,你提交了更改,并推送到 GitHub:

git checkout -b feature-parse-title
git add parse_title.py
git commit -m "Add function to parse webpage title"
git push origin feature-parse-title

2.2.3 拓展案例 1:处理合并冲突

在你的团队成员也在同时工作时,他们可能已经修改了项目中的某些文件,并推送了他们的更改到 GitHub。当你尝试合并你的分支到主分支时,可能会遇到合并冲突。

解决冲突需要你手动编辑文件,合并不同的更改,并再次提交:

git fetch origin
git rebase origin/main
# 解决任何冲突
git add .
git rebase --continue
git push origin feature-parse-title -f

2.2.4 拓展案例 2:利用 Pull Request 进行代码审查

GitHub 的 Pull Request(PR)功能是代码审查和项目协作的强大工具。通过创建 PR,你可以请求将你的分支合并到主分支。这个过程允许团队成员审查代码,提出建议,确保代码质量。

在你推送你的分支后,你可以在 GitHub 上对该分支创建一个新的 PR,并等待你的团队审查。

通过这些案例,我们看到了远程仓库如何成为团队协作不可或缺的一部分。无论是推送新的更改,处理合并冲突,还是通过 Pull Request 进行代码审查,远程仓库都让我们的开发流程更加流畅和高效。让我们继续利用这些工具,共同创造更多令人激动的项目吧!

在这里插入图片描述


2.3 版本回退与冲突解决

在软件开发的过程中,回退到之前的版本和解决代码冲突是常有的情况。Git 提供了强大的工具来帮助我们管理这些情况,让我们能够优雅地处理错误和协作中的矛盾。

2.3.1 基础知识讲解

  • 版本回退:如果你发现最近的一次提交有问题,你可以使用 git checkoutgit reset 命令回到之前的某个版本。git checkout [commit_hash] 用于查看历史中的某个版本,而 git reset 用于撤销一系列的提交。
  • 冲突解决:当多人同时修改了同一部分代码并尝试合并时,Git 会提示冲突。解决冲突需要手动编辑冲突的文件,选择要保留的更改,然后再次提交。

2.3.2 重点案例:修复一个破坏性的提交

假设在你的 Python 项目中,你不小心提交了一个包含严重错误的代码,这个错误甚至可能导致应用崩溃。你需要立刻修复这个问题,而不影响项目的其他部分。

步骤 1:定位错误提交

首先,使用 git log 定位到那个有问题的提交。假设提交的哈希是 abc123

步骤 2:回退更改

你决定使用 git revert 来回退这个更改,这将创建一个新的提交,撤销之前的更改,而不丢失之后的工作。

git revert abc123

现在,错误已经被安全地撤销,而且项目的其他部分保持不变。

2.3.3 拓展案例 1:合并时解决冲突

你和你的团队成员都对 utils.py 进行了修改,当你尝试合并他的分支时,遇到了冲突。

步骤 1:开始合并

git merge feature/teammate-branch

步骤 2:解决冲突

Git 会告诉你 utils.py 存在冲突。打开这个文件,你会看到类似下面的标记,显示了冲突的部分:

<<<<<<< HEAD
# 你的更改
=======
# 团队成员的更改
>>>>>>> feature/teammate-branch

手动编辑这个文件,解决冲突,然后保存。

步骤 3:完成合并

git add utils.py
git commit -m "Resolve merge conflict in utils.py"

2.3.4 拓展案例 2:使用 git rebase 保持清洁的提交历史

为了保持项目历史的清晰,你决定在将你的分支合并到 main 分支之前,先将你的分支上的更改进行变基操作,使其基于 main 分支的最新状态。

步骤 1:从 main 分支获取最新的更改

git checkout main
git pull

步骤 2:变基你的分支

git checkout feature/your-branch
git rebase main

如果在变基过程中遇到冲突,解决它们,然后使用 git rebase --continue 继续变基过程,直到完成。这样,你的分支上的更改就会出现在 main 分支更改的顶部,使得合并变得更简单、历史更清晰。

通过掌握版本回退和冲突解决的技巧,你就能更自信地处理项目中的错误和协作问题。记住,Git 提供了强大的工具来帮助我们优雅地管理这些挑战,让我们能够专注于创造伟大的软件。

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

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

相关文章

midnightsun-2018-flitbip:任意地址写

题目下载 启动脚本 启动脚本如下&#xff0c;没开启任何保护 #!/bin/bash qemu-system-x86_64 \-m 128M \-kernel ./bzImage \-initrd ./initrd \-nographic \-monitor /dev/null \-append "nokaslr root/dev/ram rw consolettyS0 oopspanic paneic1 quiet" 2>…

预测模型:MATLAB线性回归

1. 线性回归模型的基本原理 线性回归是统计学中用来预测连续变量之间关系的一种方法。它假设变量之间存在线性关系&#xff0c;可以通过一个或多个自变量&#xff08;预测变量&#xff09;来预测因变量&#xff08;响应变量&#xff09;的值。基本的线性回归模型可以表示为&…

备战蓝桥杯---动态规划(基础2)

本专题主要是介绍几个比较经典的题目&#xff1a; 假设我们令f[i]为前i个的最长不下降子序列&#xff0c;我们会发现难以转移方程很难写&#xff08;因为我们不知道最后一个数&#xff09;。 于是&#xff0c;我们令f[i]为以i结尾的最长不下降子序列&#xff0c;这样子我们就可…

香港倾斜模型3DTiles数据漫游

谷歌地球全香港地区倾斜摄影数据&#xff0c;通过工具转换成3DTiles格式&#xff0c;将这份数据完美加载到三维数字地球Cesium上进行完美呈现&#xff0c;打造香港地区三维倾斜数据覆盖&#xff0c;完美呈现香港城市壮美以及维多利亚港繁荣景象。再由12.5米高分辨率地形数据&am…

SpringCloud-Ribbon:负载均衡(基于客户端)

6. Ribbon&#xff1a;负载均衡(基于客户端) 6.1 负载均衡以及Ribbon Ribbon是什么&#xff1f; Spring Cloud Ribbon 是基于Netflix Ribbon 实现的一套客户端负载均衡的工具。简单的说&#xff0c;Ribbon 是 Netflix 发布的开源项目&#xff0c;主要功能是提供客户端的软件负…

【Java EE】----SpringBoot的日志文件

1.SpringBoot使用日志 先得到日志对象通过日志对象提供的方法进行打印 2.打印日志的信息 3.日志级别 作用&#xff1a; 可以筛选出重要的信息不同环境实现不同日志级别的需求 ⽇志的级别分为&#xff1a;&#xff08;1-6级别从低到高&#xff09; trace&#xff1a;微量&#…

SCI 1区论文:Segment anything in medical images(MedSAM)[文献阅读]

基本信息 标题&#xff1a;Segment anything in medical images中文标题&#xff1a;分割一切医学图像发表年份: 2024年1月期刊/会议: Nature Communications分区&#xff1a; SCI 1区IF&#xff1a;16.6作者: Jun Ma; Bo Wang(一作&#xff1b;通讯)单位&#xff1a;加拿大多…

排序算法---插入排序

原创不易&#xff0c;转载请注明出处。欢迎点赞收藏~ 插入排序是一种简单直观的排序算法&#xff0c;它的基本思想是将待排序的元素分为已排序和未排序两部分&#xff0c;每次从未排序部分中选择一个元素插入到已排序部分的合适位置&#xff0c;直到所有元素都插入到已排序部分…

微软技术专家带你学 AI|Azure OpenAI 服务

点击蓝字 关注我们 编辑&#xff1a;Alan Wang 排版&#xff1a;Rani Sun 微软技术专家带你学 AI 新的一年&#xff0c;为帮助开发者们在 Azure 上掌握人工智能&#xff0c;我们特别带来「微软技术专家带你学 AI」系列&#xff0c;通过4期的课程&#xff0c;带大家从机器学习的…

ES高可用架构涉及常用功能整理

ES高可用架构涉及常用功能整理 1. es的高可用系统架构和相关组件2. es的核心参数2.1 常规配置2.2 特殊优化配置2.2.1 数据分片按ip打散2.2.2 数据分片机架感知2.2.3 强制要求数据分片机架感知2.2.4 写入线程池优化2.2.5 分片balance优化2.2.6 限流控制器优化 3. es常用命令3.1 …

在屏蔽任何FRP环境下从零开始搭建安全的FRP内网穿透服务

背景 本人目前在境外某大学读博&#xff0c;校园网屏蔽了所有内网穿透的工具的数据包和IP访问&#xff0c;为了实现在家也能远程访问服务器&#xff0c;就不得不先开个学校VPN&#xff0c;再登陆。我们实验室还需要访问另一个大学的服务器&#xff0c;每次我都要去找另一个大学…

海外云手机——平台引流的重要媒介

随着互联网的飞速发展&#xff0c;跨境电商、短视频引流以及游戏行业等领域正经历着迅猛的更新换代。在这个信息爆炸的时代&#xff0c;流量成为至关重要的资源&#xff0c;而其中引流环节更是关乎业务成功的关键。海外云手机崭露头角&#xff0c;成为这一传播过程中的重要媒介…

消息中间件:Puslar、Kafka、RabbigMQ、ActiveMQ

消息队列 消息队列&#xff1a;它主要用来暂存生产者生产的消息&#xff0c;供后续其他消费者来消费。 它的功能主要有两个&#xff1a; 暂存&#xff08;存储&#xff09;队列&#xff08;有序&#xff1a;先进先出 从目前互联网应用中使用消息队列的场景来看&#xff0c;…

【龙年大礼】| 2023中国开源年度报告!

【中国开源年度报告】由开源社从 2015 年发起&#xff0c;是国内首个结合多个开源社区、高校、媒体、风投、企业与个人&#xff0c;以纯志愿、非营利的理念和开源社区协作的模式&#xff0c;携手共创完成的开源研究报告。后来由于一些因素暂停&#xff0c;在 2018 年重启了这个…

Qt PCL学习(二):点云读取与保存

注意事项 版本一览&#xff1a;Qt 5.15.2 PCL 1.12.1 VTK 9.1.0前置内容&#xff1a;Qt PCL学习&#xff08;一&#xff09;&#xff1a;环境搭建 0. 效果演示 1. pcl_open_save.pro QT core guigreaterThan(QT_MAJOR_VERSION, 4): QT widgets// 添加下行代码&#…

[word] word2019段落中创建纵横混排的方法图解教程 #知识分享#其他#职场发展

word2019段落中创建纵横混排的方法图解教程 有时候在word文档中需要让文字纵横混排&#xff0c;word2019正好为我们带来了纵横混排的功能了&#xff0c;今天我们就来给大家介绍一下word2019段落中创建纵横混排的方法。 步骤1&#xff1a;打开Word文档&#xff0c;选中需要纵向…

MT4和MT5中如何创建挂单,很简单,fpmarkets1秒教会

其实在MT4和MT5中创建挂单是非常容易的&#xff0c;今天fpmarkets1秒教会&#xff0c;接下来一步一步的演示&#xff1a; 首先单击新订单&#xff0c;将出现设置窗口。在“类型”选项卡中选择“按待定顺序”。 接着选择挂单的类型。选择买入止损单&#xff0c;并指定订单执行的…

【Leetcode】236. 二叉树的最近公共祖先

文章目录 题目思路代码结果 题目 题目链接 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个节点 p、q&#xff0c;最近公共祖先表示为一个节点 x&#xff0c;满足 x 是 p、q 的祖先且 x 的深度尽可…

Python爬虫http基本原理#2

Python爬虫逆向系列&#xff08;更新中&#xff09;&#xff1a;http://t.csdnimg.cn/5gvI3 HTTP 基本原理 在本节中&#xff0c;我们会详细了解 HTTP 的基本原理&#xff0c;了解在浏览器中敲入 URL 到获取网页内容之间发生了什么。了解了这些内容&#xff0c;有助于我们进一…

攻防世界 CTF Web方向 引导模式-难度1 —— 1-10题 wp精讲

目录 view_source robots backup cookie disabled_button get_post weak_auth simple_php Training-WWW-Robots view_source 题目描述: X老师让小宁同学查看一个网页的源代码&#xff0c;但小宁同学发现鼠标右键好像不管用了。 不能按右键&#xff0c;按F12 robots …