C++学习之金融类安全传输平台项目git

目录

1.知识点概述

2.版本控制工具作用

3.git和SVN

4.git介绍

5.git安装

6.工作区 暂存区 版本库概念

7.本地文件添加到暂存区和提交到版本库

8.文件的修改和还原

9.查看提交的历史版本信息

10.版本差异比较

11.删除文件

12.本地版本管理设置忽略目录

13.远程git仓库介绍

14.创建远程仓库

15.本地仓库中项目推送到远程仓库

16.将远程仓库内容克隆到本地

17.克隆应用场景

18.生成rsa密钥对

19.设置本地ssh秘钥

20.远程仓库ssh公钥设置

21.使用ssh地址进行仓库操作注意事项

22.分支介绍

23.分支的切换

24.合并分支和解决冲突

25.往远程非空仓库推动本地仓库内容

26.git提交代码操作

27.protobu部署


1.知识点概述

1.1. 版本控制系统

- 集中式版本控制系统

  > 集中式版本控制系统,版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。
  >
  > 集中式版本控制系统最大的毛病就是必须联网才能工作,如果在局域网内还好,带宽够大,速度够快,可如果在互联网上,遇到网速慢的话,那就GG了.  

2.版本控制工具作用

3.git和SVN

> 版本库又名仓库,英文名**repository**,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。

## 2.1 概念

- 工作区

  - 用户自己创建的目录 -> 存放源代码
  - 本地的版本库也需要放到工作区中
  - 每个工作区中都可以创建一个版本库
  - 只有工作区的`新文件`才需要添加到暂存区

- 版本库

  - 就是一个目录: 名字-> .git
  - 管理用于提交的代码

- 暂存区

  - 首先创建新文件 -> 在工作区 (和版本库没有关系)
  - 将新文件添加到本地仓库中 -> 新文件被保存在了暂存区 (还是没有进行版本管理)
  - 将暂存区数据提交到版本库 -> 这时候就可以进行版本管理了
  - 暂存区也是一个目录: stage/index

4.git介绍

5.git安装

创建版本库

  - 在工作区中鼠标右键

    ![1566526442145](assets/1566526442145.png)

    ![1566526474770](assets/1566526474770.png)

    ![1566526548563](assets/1566526548563.png)

- 添加新文件

  - 在工作区右键菜单

    ![1566528567183](assets/1566528567183.png)

    ![1566528599191](assets/1566528599191.png)

6.工作区 暂存区 版本库概念

7.本地文件添加到暂存区和提交到版本库

8.文件的修改和还原

9.查看提交的历史版本信息

10.版本差异比较

11.删除文件

12.本地版本管理设置忽略目录

13.远程git仓库介绍

14.创建远程仓库

15.本地仓库中项目推送到远程仓库

16.将远程仓库内容克隆到本地

17.克隆应用场景

18.生成rsa密钥对

19.设置本地ssh秘钥

20.远程仓库ssh公钥设置

21.使用ssh地址进行仓库操作注意事项

22.分支介绍

23.分支的切换

24.合并分支和解决冲突

25.往远程非空仓库推动本地仓库内容

- 远程仓库设置公钥

  - 进入当前用户的设置界面

    ![1566545689936](assets/1566545689936.png)

    ![1566545737164](assets/1566545737164.png)

    ![1566545824011](assets/1566545824011.png)

  - 使用ssh地址遇到的问题

    ![1566546069055](assets/1566546069055.png)

    ```shel
    # 解决方案: 需要修改tortoisegit 使用的 ssh工具
    # 需要在 tortoisegit 设置窗口中进行修改
    ```

    - 默认的路径

      ![1566546228805](assets/1566546228805.png)

    - 修改后的路径

      ![1566546372033](assets/1566546372033.png

26.git提交代码操作

## 6.1 创建分支

![1566547011380](assets/1566547011380.png)

![1566547074035](assets/1566547074035.png)

## 6.2 切换分支

![1566547131012](assets/1566547131012.png)

![1566547316804](assets/1566547316804.png)

## 6.3 合并分支

> 两个分支进行合并(master, new分支), 最终要合并到那个分支(master), 就先切换到那个分支(master), 切换完成之后, 在选择把哪个分支(new分支)合并到当前分支(master)

![1566548777614](assets/1566548777614.png)

![1566548823482](assets/1566548823482.png)

## 6.4 解决冲突

![1566549020854](assets/1566549020854.png)

![1566549064722](assets/1566549064722.png)

27.protobu部署

直接推送 -> 失败

![1566549817839](assets/1566549817839.png)

> 失败的原因:
>
> - 远程仓库不是空的
>   - 有一个默认分支, `master`
> - 本地仓库, 不是空的
>   - 有一个默认分支, `master`
> - 远程仓库和本地仓库默认分支名字相同, 但是这两个分支没有任何关系
>   - 没有关系的分支进行合并 -> 失败

- 解决方案

  > 1. 将远程仓库拉取到本地(pull)
  >    - 拉取: 直接将远程仓库分支中的信息和本地分支进行合并
  >    - 获取: 将远程仓库分支复制到本地的另外一个分支中, 不会合并
  >      - 分支名字: fetch_head
  > 2. 将两个分支进行强行合并
  > 3. 将本地分支数据推送动到远程仓库

- 通过进行获取操作, 得到新分支`FETCH_HEAD`

![1566550553280](assets/1566550553280.png)

- 合并分支: 得到的新分支`FETCH_HEAD`分支合并到本地`master`分支

![1566550645559](assets/1566550645559.png)

![1566550709001](assets/1566550709001.png)

- 将本地仓库推动到远程仓库

![1566550772679](assets/1566550772679.png)

# 8. 使用最多的场景

> 远程仓库分支和本地仓库分支有关系的情况, 该如何操作?
>
> - 本地:
>   - 修改代码提交到本地仓库
>   - 提交到远程仓库
>     - 不能直接提交
>     - 在推送之前应该将远程仓库代码`拉取`到本地
>       - 进程代码合并
>         - 有可能冲突 -> 手动解决冲突
>     - 将新的代码推动到远程仓库

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

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

相关文章

【HCIP】GRE VPN实验笔记

一、实验拓扑 二、实验要求 1、按照图示配置IP地址 2、在R1和R3上配置默认路由使公网区域互通 3、在R1和R3上配置GRE VPN,使两端私网能够互相访问,Tunnel口IP地址如图 4、在R1和R3上配置RIPv2或者ospf或者静态,来传递两端私网路由 三、实…

大模型——Llama Stack快速入门 部署构建AI大模型指南

Llama Stack快速入门 部署构建AI大模型指南 介绍 Llama Stack 是一组标准化和有主见的接口,用于如何构建规范的工具链组件(微调、合成数据生成)和代理应用程序。我们希望这些接口能够在整个生态系统中得到采用,这将有助于更轻松地实现互操作性。 Llama Stack 定义并标准化…

ALOPS智能化运维管理平台

AIOps(Artificial Intelligence for IT Operations)即智能运维,是将人工智能技术应用于 IT 运维管理领域,以实现自动化、智能化的运维决策和管理。以下是关于 AIOps 的详细介绍: 核心能力 数据收集与整合&#xff1a…

C语言超详细指针知识(二)

在上一篇有关指针的博客中,我们介绍了指针的基础知识,如:内存与地址,解引用操作符,野指针等,今天我们将更加深入的学习指针的其他知识。 1.指针的使用和传址调用 1.1strlen的模拟实现 库函数strlen的功能是…

一种替代DOORS在WORD中进行需求管理的方法 (二)

一、前景 参考: 一种替代DOORS在WORD中进行需求管理的方法(基于WORD插件的应用)_doors aspice-CSDN博客 二、界面和资源 WORD2013/WORD2016 插件 【已使用该工具通过第三方功能安全产品认证】: 1、 核心功能 1、需求编号和跟…

设计模式 Day 6:深入讲透观察者模式(真实场景 + 回调机制 + 高级理解)

观察者模式(Observer Pattern)是一种设计结构中最实用、最常见的行为模式之一。它的魅力不仅在于简洁的“一对多”事件推送能力,更在于它的解耦能力、模块协作设计、实时响应能力。 本篇作为 Day 6,将带你从理论、底层机制到真实…

文献总结:AAAI2025-UniV2X-End-to-end autonomous driving through V2X cooperation

UniV2X 一、文章基本信息二、文章背景三、UniV2X框架1. 车路协同自动驾驶问题定义2. 稀疏-密集混合形态数据3. 交叉视图数据融合(智能体融合)4. 交叉视图数据融合(车道融合)5. 交叉视图数据融合(占用融合)6…

2025蓝桥杯python A组题解

真捐款去了,好长时间没练了,感觉脑子和手都不转悠了。 B F BF BF 赛时都写假了, G G G 也只写了爆搜。 题解其实队友都写好了,我就粘一下自己的代码,稍微提点个人的理解水一篇题解 队友题解 B 思路: 我…

免费送源码:Java+ssm+MySQL 校园二手书销售平台设计与实现 计算机毕业设计原创定制

摘 要 信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题。针对校园二手书销售平台等问题,对校…

工业科学级天文相机:跨界融合的高精密成像解决方案

随着国内科技的快速发展,工业相机领域正悄然兴起一场"天文级"的技术革命。这类兼具工业设备可靠性与天文观测精度的特殊相机,正在半导体制造、天文观测、空间探测等领域开辟新的应用疆域。其核心技术突破不仅体现在传感器性能的提升&#xff0…

论文阅读笔记——Multi-Token Attention

MTA 论文 在 Transformer 中计算注意力权重时,仅依赖单个 Q 和 K 的相似度,无法有效捕捉多标记组合信息。(对于 A、B 两个词,单标记注意力需要分别计算两个词的注意力分数,再通过后处理定位共同出现的位置或通过多层隐…

301.找出3位偶数

2094. 找出 3 位偶数 - 力扣&#xff08;LeetCode&#xff09; class Solution {List<Integer> resnew ArrayList<>();List<Integer> linew ArrayList<>();public int[] findEvenNumbers(int[] digits) {Arrays.sort(digits);boolean[] numsnew boolea…

【KWDB 创作者计划】第二卷:开发者实战篇

​KWDB技术白皮书卷二&#xff1a;开发者实战篇 ​1. 自然语言到量子查询的编译系统 1.1 NL2QSQL翻译引擎架构 运行时流程图解&#xff1a; ┌──────────────────────┐ ┌───────────────────┐ ┌─────────────…

前端工程化之新晋打包工具

新晋打包工具 新晋打包工具前端模块工具的发展历程分类初版构建工具grunt使用场景 gulp采用管道机制任务化配置与api简洁 现代打包构建工具基石--webpack基于webpack改进的构建工具rollup 推荐举例说明package.jsonrollup.config.mjsmy-extract-css-rollup-plugin.mjssrc/index…

ai软件UI自动化

在AI与UI自动化结合的场景中,通常涉及计算机视觉(CV)、自然语言处理(NLP)和机器学习(ML)等技术。以下是实现AI驱动UI自动化的关键方向、工具和步骤: ‌一、核心应用场景‌ ‌元素定位增强‌ ‌问题‌:传统工具依赖XPath/CSS选择器,易因UI变化失效。‌AI方案‌:CV识别…

关于 C++ 中 cin 对象和 EOF 的详细解释

【DeepSeek提问】 给解释一下下面这段话&#xff08;C编程&#xff09; cin是 iostream 类的一个对象实例&#xff0c;如果输入正常&#xff0c; cin 将返回本身。 举个例子&#xff1a;cin>x>>y, 如果 cin>>x 读入正常&#xff0c;那么将返回cin, 相当于后面继…

Vue 3 和 Vue 2 的区别及优点

Vue.js 是一个流行的 JavaScript 框架&#xff0c;广泛用于构建用户界面和单页应用。自 Vue 3 发布以来&#xff0c;很多开发者开始探索 Vue 3 相较于 Vue 2 的新特性和优势。Vue 3 引入了许多改进&#xff0c;优化了性能、增强了功能、提升了开发体验。本文将详细介绍 Vue 2 和…

【特权FPGA】之UART串口

0.简介 通用异步收发器(Universal Asynchronous Receiver&#xff0f;Transmitter&#xff0c;UART)可以和各种标准串行接口&#xff0c;如RS 232和RS 485等进行全双工异步通信&#xff0c;具有传输距离远、成本低、可靠性高等优点。一般UART由专用芯片如8250&#xff0c;1645…

Vue3中watch监视reactive对象方法详解

在Vue3中&#xff0c;使用watch监视reactive对象时&#xff0c;需根据监视的目标选择合适的方法。以下是详细的步骤和说明&#xff1a; 1. 监视整个reactive对象 自动深度监视&#xff1a;直接监视reactive对象时&#xff0c;Vue3会默认启用深度监视&#xff0c;无需设置deep:…

如何制定性能调优策略

目录 性能测试攻略 微基准性能测试 宏基准性能测试 热身问题 多 JVM 情况下的影响 合理分析结果&#xff0c;制定调优策略 推荐阅读 性能测试攻略 性能测试是提前发现性能瓶颈&#xff0c;保障系统性能稳定的必要措施。下面我先给你介绍两种常用 的测试方法&#xff0c;帮…