当前位置: 首页 > news >正文

一篇文章掌握Git的基本原理与使用

目录

一、创建仓库

1.1 git init

1.2 git clone

二、工作区域与文件状态

三、添加和提交文件

3.1 git status

3.2 git add

git rm --cached

3.3 git commit

git log

四、版本回退

soft

hard

mixed

总结

五、查看差异

工作区与暂存区

工作区与本地仓库

暂存区与本地仓库

版本差异

分支差异

六、删除文件

git rm

git rm --cached file

六、.gitignore 忽略文件

七、分支

7.1git branch显示分支

7.2git branch 分支名创建分支

7.3git switch 分支名切换分支

7.4 git merge src des合并src分支至des分支

7.5 rebase 变基

7.6 git branch -d 分支名删除已合并的分支

7.7 git branch -D 分支名删除未合并的分支

八、解决合并冲突

8.1 设计冲突

8.2 冲突现象

8.3 解决冲突

九、版本回退


一、创建仓库

1.1 git init

使用 git init 初始化git仓库,然后可以使用ls -a查看隐藏的目录结构观察到.git目录

1.2 git clone

使用git clone 可以从远程仓库拉取仓库到本地

二、工作区域与文件状态

git 分为三个区域,分别是工作区(Working Directory)、暂存区(Staging Area/Index)、本地仓库(Local Repository):

  • 工作区:实际操作的目录
  • 暂存区:相当于一个缓冲区,临时存放即将提交的修改内容
  • 本地仓库:Git存储代码和版本信息的主要位置

    Git中的文件也存在各自的状态,如下:
  • 未跟踪:新创建的还没有被Git管理起来的文件
  • 未修改:已经被Git管理,但是文件的内容没有发生变化
  • 已修改:已经被修改的文件,但是还没有被添加到暂存区
  • 已暂存:已经被修改过并放入暂存区的文件
    可以使用git ls-files查看暂存区的文件内容
    可以使用git -ltr查看本地仓库的文件内容

三、添加和提交文件

3.1 git status

可以使用git status查看当前工作区的文件状态,下面新建一个文件,使用status后发现文件飘红,这就是未跟踪的文件:

3.2 git add

可以使用git add将文件添加到暂存区,可以看到刚才飘红的file1.txt已经变成绿色,这表示该文件已经被添加到暂存区:

git add还支持通配符与文件夹的添加,如
git add \*.txt git add dir1/,分别表示添加所有以txt结尾的文件与dir1下的所有文件

git rm --cached

在上图中可以看到,绿色的字体上方有一句提示,使用该命令可以将文件从暂存区中删除:

需要注意的是,<file> 中的 < 和 > 是特殊字符,在 Zsh 中具有特殊含义(例如重定向)。如果你希望直接使用文件名 file1.txt,不需要加 < 和 >。

3.3 git commit

将暂存区的文件添加到本地仓库,它只会与暂存区和本地仓库交互,并不影响工作区的文件,

  1. 除此之外,使用git commit提交时要使用-m选项指定文件的提交信息,
  2. 如果不使用-m,则默认使用vim来编辑提交信息:

git log

git log可以查看所有已经提交的提交信息

可以加上其他选项,如--oneline,这样就会显示比较简洁的提交信息:

四、版本回退

使用git reset时,需要在后面加上回退的版本ID,或者使用 HEAD^ 表示上一个版本
可以使用git reset进行版本回退,同时其支持三种模式:

  • git reset --soft:保留工作区与暂存区的所有修改内容
  • git reset --hard:丢弃工作区与暂存区的所有修改内容
  • git reset --mixed(default):保留工作区,丢弃暂存区的修改内容
    再次新建三个文件,分两次提交,第一次提交前两个文件,第二次提交第三个文件:

    接着使用git log查看提交历史:

soft

  • 当你提交后,发现提交信息有问题或漏加了一些文件时,可以回退到提交之前的状态,保留文件变更。
    使用soft回退到提交两次文件的版本后,使用git log查看,可以看到提交历史已经成功回退到提交两次文件的时候:

    查看工作区与暂存区的文件,可以看打它们都没有被删除,且因为回退到了3.txt未被提交的版本,这里显示其是一个新文件:

hard

  • 彻底清理: 当你需要放弃所有未提交的更改和暂存内容,回到某个提交的状态。
  • 切换分支时冲突太多:如果切换分支或合并导致大量冲突,并且你决定完全放弃当前的更改,可以使用
    回退前:

    回退后:

    查看工作区与暂存区的内容,发现3.txt都被删除了:

mixed

撤销提交并重新整理文件:当你需要取消提交,同时希望对文件进行修改或重新选择哪些文件需要暂存时。
回退前:

回退后:

查看工作区与暂存区,可以发现工作区的3.txt未被删除,但是暂存区的已经被删除:

总结


如果误删除,也不需要担心,可以使用git reflog查看操作的历史记录,然后继续使用git reset进行回溯:

五、查看差异

可以使用git diff查看以下内容:

  • 工作区、暂存区、本地仓库之间的差异
  • 查看不同版本的差异
  • 查看不同分支之间的差异
    目前有三次提交:

工作区与暂存区

现在要修改3.txt的内容,然后使用git diff查看:


以上内容说明3.txt修改的内容还没有被添加到暂存区,现在将其添加到暂存区后查看:


可以看到已经没有任何的内容了,表示工作区与暂存区的内容是相同的。

工作区与本地仓库

使用git diff HEAD查看工作区与本地仓库的差异:

暂存区与本地仓库

使用git diff --cached查看暂存区与本地仓库的差异:

版本差异

使用git diff 版本1ID 版本2ID可以比较版本差异,

  • HEAD指向最新一次提交,也可以使用其指代最新的一次提交。
    • HEAD~表示上一次提交。
    • HEAD~2表示本次提交前的第二个版本。
  • 可以在后面加上文件名,这样只会比较该文件的版本差异

分支差异

使用git diff 分支1名 分支2名可以查看分支间的差异,具体内容需要看分支小节

六、删除文件

首先查看本地仓库的文件内容:


正常删除文件的流程:

  1. 删除本地文件
  2. 使用git add更新暂存区列表
  3. 使用git commit更新本地仓库

git rm

git中提供git rm命令,可以合并上述的步骤1与步骤2,


但是最后还是要执行git commit删除本地仓库的文件:
执行git commit前:


执行git commit后:

git rm --cached file

如果只需要删除暂存区的文件,可以使用该命令

六、.gitignore 忽略文件

可以创建一个.gitignore文件,在其中添加需要忽略的文件:

此时git就会主动忽略与.gitignore中的文件格式相同的文件:


需要注意的是,git只会忽略.gitignore提交以后生成的文件,如果在.gitignore提交前生成的文件,git还是会进行跟踪。

七、分支

7.1git branch显示分支

可以看到 main 前有一个*,这其实就是HEAD指针,它指向的是当前分支:

7.2git branch 分支名创建分支


在创建分支时,该分支会继承本分支上的提交记录:
 

7.3git switch 分支名切换分支


在当前分支下创建两个文件并提交到本地仓库,然后切换分支,来观察main分支是否存在新建的文件:
 


当我们在不同分支间切换时,其实就是HEAD指针指向的改变,这也就解释了为什么在testing分支提交的文件,在main分支不可见:


此时在main分支提交两个文件后,则底层实现会变为:


注:为了方便观察,这里使用提交信息代替了版本ID

7.4 git merge src des合并src分支至des分支

在合并之前,需要先进入des分支

7.5 rebase 变基

rebase 分支名将当前分支变基到指定的分支。
变基(Rebase) 是 Git 中一种重新整理提交历史的操作,它会将一个分支的提交应用到另一个分支的基础之上。
 

7.6 git branch -d 分支名删除已合并的分支

7.7 git branch -D 分支名删除未合并的分支

八、解决合并冲突

如果两个分支修改了一份文件的同一行代码,git就不知道应该保留哪个内容,也就产生了冲突:

8.1 设计冲突

我们来重新设计一下,用main分支新建文件并提交后新建newb分支:

在newb分支修改main.txt的第二行内容并提交:

切换回main分支修改main.txt的第二行内容并提交:

8.2 冲突现象

尝试合并:

可以使用git diff查看冲突:

8.3 解决冲突

在合并失败后,可以再次编辑该文件,此时文件中就会存在冲突的信息:

此时就需要手动编辑来解决冲突:

当冲突解决后,进行添加与提交,提交后就会自动合并:

如果中途想终止合并,也可以使用git merge --abort

九、版本回退

git checkout -b 分支名 提交ID可以回退到指定的版本
其中,提交ID可以通过git log --oneline --graph --decorate --all查看,同时该指令也可以比较直观的查看当前所有分支。

相关文章:

一篇文章掌握Git的基本原理与使用

目录 一、创建仓库 1.1 git init 1.2 git clone 二、工作区域与文件状态 三、添加和提交文件 3.1 git status 3.2 git add git rm --cached 3.3 git commit git log 四、版本回退 soft hard mixed 总结 五、查看差异 工作区与暂存区 工作区与本地仓库 暂存区…...

「Mac畅玩鸿蒙与硬件43」UI互动应用篇20 - 闪烁按钮效果

本篇将带你实现一个带有闪烁动画的按钮交互效果。通过动态改变按钮颜色&#xff0c;用户可以在视觉上感受到按钮的闪烁效果&#xff0c;提升界面互动体验。 关键词 UI互动应用闪烁动画动态按钮状态管理用户交互 一、功能说明 闪烁按钮效果应用实现了一个动态交互功能&#xf…...

朗新科技集团如何用云消息队列 RocketMQ 版“快、准、狠”破解业务难题?

作者&#xff1a;邹星宇、刘尧 朗新科技集团&#xff1a;让数字化的世界更美好 朗新科技集团股份有限公司是领先的能源科技企业&#xff0c;长期深耕电力能源领域&#xff0c;通过新一代数字化、人工智能、物联网、电力电子技术等新质生产力&#xff0c;服务城市、产业、生活中…...

【Ubuntu】Ubuntu的Desktop(学习/用户使用)和Bit版本(工作)

这篇文章似乎没什么必要写&#xff0c;但想了想还是决定记录一下&#xff0c;也许对新手入坑Ubuntu会有帮助&#xff0c; 事实上也很简单&#xff0c;一个是桌面版本&#xff0c;另一个是字符界面版本。 桌面版&#xff1a;拥有图形桌面 字符界面&#xff0c;易上手&#xff…...

cmake CMAKE_CURRENT_SOURCE_DIR和CMAKE_CURRENT_LIST_DIR的区别

在 CMake 中&#xff0c;CMAKE_CURRENT_LIST_DIR 和 CMAKE_CURRENT_SOURCE_DIR 都是指代当前 CMake 文件所在的路径&#xff0c;但它们的含义和用途有所不同&#xff1a; CMAKE_CURRENT_LIST_DIR&#xff1a; 表示 当前处理的 CMake 文件&#xff08;例如 CMakeLists.txt&#…...

学会用VSCode debug

本文主要介绍了 VS Code 的调试功能&#xff0c;包括其强大的内置调试器&#xff0c;支持多种语言&#xff0c;如 JavaScript、TypeScript 等。通过简单项目示例展示调试过程&#xff0c;还介绍了运行面板和菜单、启动配置、调试操作、断点、记录点等功能&#xff0c;以及三种调…...

C语言专题之结构体的使用

结构体&#xff08;struct&#xff09;是一种用户自定义的数据类型&#xff0c;它允许将不同类型的数据组合在一起&#xff0c;形成一个新的数据类型。结构体在编程中非常常见&#xff0c;尤其是在需要处理复杂数据结构的情况下。以下是结构体的基本使用方法&#xff1a; 一、结…...

python中的高阶函数

1、什么是高阶函数&#xff1f; 高阶函数是指将函数作为参数传入。就是高阶函数 2、高阶函数有哪些&#xff1f; map 映射函数 >>> print(list(map(lambda x:x*x,range(1,11)))) [1, 4, 9, 16, 25, 36, 49, 64, 81, 100] >>> print(list(map(lambda x:st…...

学习笔记063——通过使用 aspose-words 将 Word 转 PDF 时,遇到的字体改变以及乱码问题

文章目录 1、问题描述&#xff1a;2、解决方法&#xff1a; 1、问题描述&#xff1a; Java项目中&#xff0c;有个需要将word转pdf的需求。本人通过使用aspose-words来转换的。在Windows中&#xff0c;转换是完全正常的。但是当部署到服务器时&#xff0c;会出现转换生成的pdf…...

SpringBoot整合Mockito进行单元测试超全详细教程 JUnit断言 Mockito 单元测试

Mock概念 Mock叫做模拟对象&#xff0c;即用来模拟未被实现的对象可以预先定义这个对象在特定调用时的行为&#xff08;例如返回值或抛出异常&#xff09;&#xff0c;从而模拟不同的系统状态。 导入Mock依赖 pom文件中引入springboot测试依赖&#xff0c;spring-boot-start…...

【AI知识】过拟合、欠拟合和正则

一句话总结&#xff1a; 过拟合和欠拟合是机器学习中的两个相对的概念&#xff0c;正则化是用于解决过拟合的方法。 1. 欠拟合&#xff1a; 指模型在训练数据上表现不佳&#xff0c;不能充分捕捉数据的潜在规律&#xff0c;导致在训练集和测试集上的误差都很高。欠拟合意味着模…...

MacOS编译webRTC源码小tip

简单记录一下&#xff0c;本人在编译webRTC时&#xff0c;碰到了一下比较烦人的问题&#xff0c;在MacOS终端下&#xff0c;搭建科学上网之后&#xff0c;chromium的depot_tools仓库成功拉下来了&#xff0c;紧接着&#xff0c;使用fetch以及gclient sync始终都返回curl相关的网…...

Linux基础命令(三):文件压缩及解压缩命令

文件压缩及解压缩命令 tar — 打包和压缩 tar 是一个用于打包文件的工具&#xff0c;常常用来将多个文件或目录打包成一个单独的文件。它本身不进行压缩&#xff0c;但可以与压缩工具&#xff08;如 gzip 或 bzip2&#xff09;一起使用。 用法&#xff1a; 打包文件&#xff0…...

目标跟踪算法:ByteTrack、卡尔曼滤波、匈牙利算法、高置信度检测目标、低置信度检测目标

目录 1 ByteTrack特点 2 ByteTrack和SORT区别----个人通俗理解 3 ByteTrack算法原理 4 ByteTrack整体流程图 上一篇博客我复习了下SORT跟踪算法&#xff0c;这一篇博客我再复习下ByteTrack跟踪算法&#xff0c;ByteTrack里面也是用了卡尔曼滤波和匈牙利算法&#x…...

[定昌linux系统]如何安装jdk8

1:下载jdk8 的 arm64 的版本&#xff0c;由于官方下载需要gmail&#xff0c;我的gmail 密码忘了&#xff0c;所以从csdn上下载了一份&#xff0c;地址&#xff1a; https://download.csdn.net/download/qq_27742163/88533548?utm_mediumdistribute.pc_relevant_download.none…...

【Cadence32】PCB多层板电源、地平面层创建心得➕CM约束管理器Analyze分析显示设置➕“DP”报错DRC

【转载】Cadence Design Entry HDL 使用教程 【Cadence01】Cadence PCB Edit相对延迟与绝对延迟的显示问题 【Cadence02】Allegro引脚焊盘Pin设置为透明 【Cadence03】cadence不小心删掉钢网层怎么办&#xff1f; 【Cadence04】一般情况下Allegro PCB设计时的约束规则设置&a…...

基于SpringBoot+Vue的新闻管理系统

系统展示 用户前台界面 管理员后台界面 系统背景 随着互联网技术的飞速发展&#xff0c;信息传播速度不断加快&#xff0c;新闻媒体行业面临着巨大的机遇与挑战。传统的新闻媒体正在逐渐向数字化转型&#xff0c;而新闻管理系统作为数字化新闻媒体的核心组成部分&#xff0c;其…...

图的割点、割边(Tarjan算法)

深度优先搜索的利用。 在一个无向连通图中&#xff0c;如果删掉某个顶点后&#xff0c;图不再连通&#xff08;即任意两点之间不能互相到达&#xff09;&#xff0c;我们称这样的顶点为割点。 在一个无向连通图中&#xff0c;如果删掉某条边后&#xff0c;图不在连通&#xff0…...

算法学习(十四)—— 二叉树的深度搜索(DFS)

目录 关于dfs 部分OJ题详解 2331. 计算布尔二叉树的值 129. 求根节点到叶节点数字之和 814. 二叉树剪枝 98. 验证二叉搜索树 230. 二叉搜索树中第K小的元素 257. 二叉树的所有路径 关于dfs 算法学习&#xff08;十二&#xff09;—— 递归&#xff0c;搜索&#xff0c…...

【vue2】封装自定义的日历组件(三)之基础添加月份的加减定位到最新月份的第一天

我们在切换月份的时候&#xff0c;希望高亮显示在每个月的第一天上面&#xff0c;这样的效果我们要怎么来实现&#xff0c;其实也很简单&#xff0c;我们先看下实现的效果 实现效果 代码实现 原理就是获取到每月的第一天日期&#xff0c;然后再跟整个的数据进行对比&#xff…...

LabVIEW偏心圆筒流变仪测控系统

偏心圆筒流变仪是一种专门研究聚合物熔体在复杂流场中特殊流变行为的先进设备。通过结合硬件控制与LabVIEW软件开发&#xff0c;本系统实现了对流变仪功能的精准控制与数据采集&#xff0c;进一步提高了聚合物加工过程的研究精度和效率。 项目背景 传统的流变测量设备多集中于…...

Runloop

假设你的项目中有关tableView&#xff0c;然后还有一个定时器timer在执行&#xff0c;定时器代码如下&#xff1a; var num 0override func viewDidLoad() {super.viewDidLoad()let timer Timer(timeInterval: 1,target: self,selector: #selector(self.run),userInfo: nil,r…...

SpringBoot的Bean类三种注入方式(附带LomBok注入)

SpringBoot的Bean类三种注入方式&#xff08;附带LomBok注入&#xff09; 在 Spring Boot 中&#xff0c;Bean 的注入方式主要包括构造函数注入&#xff08;Constructor Injection&#xff09;、字段注入&#xff08;Field Injection&#xff09;以及 Setter 方法注入&#xf…...

开源向量数据库介绍说明

开源向量数据库 Milvus 特点&#xff1a;分布式、高性能&#xff0c;支持亿级向量检索。 支持的数据类型&#xff1a;文本、图像、音频、视频等。 使用场景&#xff1a;推荐系统、语义搜索、图像搜索。 数据存储后端&#xff1a;支持多种后端&#xff0c;如 SQLite、MySQL、Pos…...

【前端】深度解析 JavaScript 中的 new 关键字与构造函数

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: 前端 文章目录 &#x1f4af;前言&#x1f4af;构造函数的核心特性&#x1f4af;new 关键字的执行机制&#x1f4af;实例代码与详细解析代码示例代码逐步解析 &#x1f4af;new 的内部执行模拟执行过程的详细解析 &am…...

2024年华中杯数学建模C题基于光纤传感器的平面曲线重建算法建模解题全过程文档及程序

2024年华中杯数学建模 C题 基于光纤传感器的平面曲线重建算法建模 原题再现 光纤传感技术是伴随着光纤及光通信技术发展起来的一种新型传感器技术。它是以光波为传感信号、光纤为传输载体来感知外界环境中的信号&#xff0c;其基本原理是当外界环境参数发生变化时&#xff0c…...

使用 `typing_extensions.TypeAlias` 简化类型定义:初学者指南

使用 typing_extensions.TypeAlias 简化类型定义&#xff1a;初学者指南 什么是 TypeAlias&#xff1f;安装 typing_extensions示例代码&#xff1a;如何使用 TypeAlias示例 1&#xff1a;为简单类型定义别名示例 2&#xff1a;为复杂类型定义别名示例 3&#xff1a;结合 Union…...

如何快速批量把 PDF 转为 JPG 或其它常见图像格式?

在某些特定场景下&#xff0c;将 PDF 转换为 JPG 图片格式却具有不可忽视的优势。例如&#xff0c;当我们需要在不支持 PDF 查看的设备或软件中展示文档内容时&#xff0c;JPG 图片能够轻松被识别和打开&#xff1b;此外&#xff0c;对于一些网络分享或社交媒体发布的需求&…...

如何在组织中塑造和强化绩效文化?

在组织中塑造和强化绩效文化是一个系统性的工程。 一、明确绩效目标与期望 设定清晰目标 组织应根据自身战略规划&#xff0c;将长期目标分解为具体、可衡量、可实现、相关联、有时限&#xff08;SMART&#xff09;的短期和中期绩效目标。例如&#xff0c;一家连锁餐饮企业的…...

OllyDbg、CE简单介绍

基础知识&#xff1a; 想要破解软件&#xff0c;需要一些基础知识&#xff1a; 文件格式&#xff1a;Windows对应PE、Linux对应ELF、IOS对应Mash-0。文件格式是指操作系统规定的每个段&#xff08;代码段、数据段、堆、栈&#xff09;的大小、顺序等信息。 汇编语言&#xff1…...