【Git 学习】

news2024/11/16 23:42:18

Git 学习

  • 一、Git的使用
        • 1. Git下载安装
        • 2. Git 命令
        • 3. Git推送代码步骤
        • 4. Git基本工作流程
        • 5. Git历史版本切换
        • 6. Git分支管理
          • 6.1 创建新分支
          • 6.2 切换分支
          • 6.3 合并分支
          • 6.4 删除分支
        • 7. 远程仓库的工作流程
          • 7.1 具体流程
        • 8.推送到远程仓库
        • 9. 代码冲突问题
        • 10. IDEA 集成Git
          • 10.1 版本切换
          • 10.2 分支切换
          • 10.3 clone项目到IDEA

一、Git的使用

  • 代码备份
  • 版本控制
  • 协同工作
  • 责任追溯

1. Git下载安装

Git下载地址:https://git-scm.com/downloads

2. Git 命令

  • git --version 显示版本
    -
    - git
  • 本地仓库存放不同版本的代码, 完成项目10%的代码,完成项目20%的代码等

3. Git推送代码步骤

在这里插入图片描述

4. Git基本工作流程

在这里插入图片描述

  • 使用命令
  • git init 初始化仓库
  • 新建文件test.txt文件 使用git status查看状态
  • 在这里插入图片描述
  • 使用 git add test.txt 将文件提交到暂存区,并使用git status 查看状态
  • 在这里插入图片描述
  • 使用 git commit -m ‘提交时输入代码的描述’ ,将文件提交到本地仓库,使用git log 查看提交日志,日志中每个版本会有唯一标识
  • 唯一标识用来区分每个版本 可以追溯回曾经的版本

5. Git历史版本切换

  • git reflog 查询所有分支的所有操作记录 (包括已经被删除的commit记录的操作)
  • git reset --hard c7b7df9 历史版本切换 版本唯一索引值

6. Git分支管理

在这里插入图片描述

6.1 创建新分支
  • git checkout -b dev 加上-b参数表示创建并切换,相当于以下两条命令
  • git branch dev git checkout dev
  • 修改工作区一个文件测试下,然后提交
    git add test.txt
    git commit -m “test”
    再切回master:
    git checkout master 会发现刚才修改的内容又回去了,没有发生变化,因为刚那个提交是在dev分支上,master分支此刻的提交并没有变
6.2 切换分支

git checkout 分支名

6.3 合并分支

切换为主分支,然后使用
合并命令: git merge 分支名(dev)

6.4 删除分支

删除分支命令:
git branch -d dev(分支名)
查看git 分支:git branch

7. 远程仓库的工作流程

在这里插入图片描述

7.1 具体流程
  1. 创建远程仓库在推送代码之前,先配置SSH公钥
    在这里插入图片描述

  2. 将user.name and user.email 修改为 global形式 在这里插入图片描述

  3. cd ~/.ssh 看是否生成过公钥,若没有则显示
    在这里插入图片描述

  4. 生成公钥:ssh-keygen -t rsa -C “你的邮箱”,之后三次回车,则在具体目录下会生成公钥

  5. 在gitee中设置SSH公钥 贴入 公钥中的id_rsa.pub ,点击验证,验证密码为 gitee登录密码
    在这里插入图片描述

  6. 验证命令:ssh -T git@gitee.com 如果成功
    在这里插入图片描述

8.推送到远程仓库

  • 使用命令: git remote add 仓库地址别名 你的远程仓库地址
  • 将代码推送命令: git push -u origin master (orgin为仓库地址别名,master为推送的分支名)
  • 将别人更新的代码拉回: git pull origin master
  • 删除关联的库: git remote rm origin

9. 代码冲突问题

正常模式 :A 拉取代码 修改提交,B也先拉取代码再修改提交
冲突: A 拉取代码 修改后提交 B没有拉取直接修改同一文件代码 ,代码产生冲突
查看冲突内容 : cat 对应的文件名

10. IDEA 集成Git

在这里插入图片描述
之后将项目 创建为git本地仓库
在这里插入图片描述

10.1 版本切换

alt+9调出历史版本
在这里插入图片描述
但是如此切换 记录会丢失
因此可以使用
在这里插入图片描述
解决差异后就可以

10.2 分支切换

点击git
在这里插入图片描述
new branch 创建新的分支 dev,checkout 就会发现右下角变成新的分支了在这里插入图片描述
在dev分支下创建的代码要进行合并,选择git merge合并分支,提交代码即可

10.3 clone项目到IDEA

在这里插入图片描述

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

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

相关文章

说说webpack的构建流程?

① 初始化流程 从配置文件和 Shell 语句中读取与合并参数,并初始化需要使用的插件和配置插件等执行环境所需要的参数。 配置文件默认下为 webpack.config.js,也可以通过命令的形式指定配置文件; 主要作用是用于激活webpack的加载项和插件&am…

手写axios源码系列一:axios核心知识点

文章目录 axios的核心功能1、axios 函数对象2、dispatchRequest 发送请求3、interceptors 拦截器4、cancelToken 取消请求 最近从头搭建了一个vue小项目,想使用 axios 作为请求接口的第三方库。结果使用了 axios 这么长时间,想封装一下 axios &#xff0…

Nacos2.2.2开启鉴权配置

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、更改application.properties中的配置二、修改配置 前言 最近公司开启了一个新的电商项目,项目中用到了Naocs作为注册中心和配置中心&#xff0…

WindowsUbuntu下python程序打包

Python程序的运行必须要有Python的环境,但是程序编出来是用的,如果是给别人用,而他/她的电脑上又没有Python程序运行的环境怎么办呢?总不能让他/她去安装一个吧?这时我们就要将Python程序打包为exe可执行文件&#xff…

【文章学习系列之模型】PatchTST

本章内容 文章概况模型结构实验结果长期预测表征学习 消融实验分块和通道独立性不同的回顾窗口 总结 文章概况 《A Time Series is Worth 64 Words: Long-term Forecasting with Transformers》是2023年发表于ICLR的一篇文章。该文章借鉴了计算机视觉领域的Vision Transformer…

树形DP分析

树形dp 简单来说树形 d p 就是在树上做 d p 罢了 简单来说树形dp就是在树上做dp罢了 简单来说树形dp就是在树上做dp罢了 树嘛,就要符合除了根节点外每个节点只有一个父节点 树嘛,就要符合除了根节点外每个节点只有一个父节点 树嘛,就要符合除…

# 从车灯模组的角度聊聊信息安全需求

文章目录 1. 前言2.信息安全需求2.1 硬件安全2.1.1 接口安全2.1.2 主板安全2.1.3 芯片安全 2.3 系统安全2.3.1 代码安全2.3.2 软件读保护2.3.3 安全启动2.3.4 安全升级2.3.5 安全诊断 2.4 通信安全2.5 数据安全 3. 安全启动流程3.1 基于签名技术的安全启动方案3.2 基于对称签名…

netty源码阅读--处理客户端请求

背景 netty是一个非常成熟的NIO框架,众多apache的顶级项目底层通信框架都是用的是netty,本系列博客主要是记录自己复习netty源码的过程,重在理解netty的关键如:如何启动,如何接受网络数据、netty的内存管理机制以及编解码器等&am…

Python学习笔记--面向对象

未完待续。。。。。 (一)面向对象的基本概念 我们之前学习的编程方式就是面向过程的 面相过程和面相对象,是两种不同的编程方式 对比面向过程的特点,可以更好地了解什么是面向对象 1.1过程和函数 过程是早期的一个编程概念 过程…

4.3 分段低次插值

学习目标: 如果我要学习分段低次插值,我可能会采取以下几个步骤: 学习插值的基本概念和方法 在学习分段低次插值之前,我需要先掌握插值的基本概念和方法,例如拉格朗日插值、牛顿插值和内维尔方法等。这些基础知识可…

C#调用C++封装的SDK库(dll动态库)——上

C#调用C封装的SDK库(dll动态库)——上 一、C封装库 通过前几篇文章,我们封装了C的动态DLL库,有Qt版的,有C版的,当然还有介绍了Pimpl模式在SDK封装中的使用: Qt创建SDK VS创建SDK Pimple在SDK封装中的应用 但是&a…

关于逻辑回归的几个函数

写作业时重新理了下,如果有问题欢迎指正! 说是回归,其实就是个分类,用【0,1】标记结果y是录取还是录取,而影响结果y的就是X(x0,x1,…xn-1)。怎么判断结果y是0还是1用到的是逻辑回归函数(也叫假…

java企业级信息系统开发学习笔记05 初探Spring AOP

文章目录 一、学习目标二、Spring AOP(一)AOP基本含义(二)AOP基本作用(三)AOP和OOP对比(四)AOP使用方式(五)AOP基本概念 三、采用配置方法使用AOP&#xff08…

windows下Tomcat安装

目录 1.安装java环境 2.配置Tomcat环境变量 3.安装服务 4.启动前修改配置文件 (1)设置tomcat端口 (2)设置临时日志等文件夹的位置 5.放入应用 6.启动Tomcat服务 1.安装java环境 安装tomcat版本对应的JDK 比如:…

Mysql的简介和选择

文章目录 前言一、为什么要使用数据库 数据库的概念为什么要使用数据库二、程序员为什么要学习数据库三、数据库的选择 主流数据库简介使用MySQL的优势版本选择四、Windows 平台下安装与配置MySQL 启动MySQL 服务控制台登录MySQL命令五、Linux 平台下安装与配置MySQL总结 前言…

Redis 分布式锁解决方案

1 背景 我们日常在电商网站购物时经常会遇到一些高并发的场景,例如电商 App 上经常出现的秒杀活动、限量优惠券抢购,还有我们去哪儿网的火车票抢票系统等,这些场景有一个共同特点就是访问量激增,虽然在系统设计时会通过限流、异步…

设计模式:行为型模式 - 责任链模式

文章目录 1.概述2.结构3.案例实现4.优缺点5.源码解析 1.概述 在现实生活中,常常会出现这样的事例:一个请求有多个对象可以处理,但每个对象的处理条件或权限不同。例如,公司员工请假,可批假的领导有部门负责人、副总经…

链表方式实现栈和队列(C语言)

目录 栈 队列 栈 栈(Stack)是一种常见的数据结构,它是一种线性数据结构,具有后进先出(Last In First Out, LIFO)的特点。栈可以看作是一个容器,只能在容器的一端进行插入和删除操作&#xff0c…

【12 Filter 学习笔记】

Filter 笔记记录 1. Filter 过滤器2. Filter介绍3. FilterChain3. Filter 过滤器的使用4. 过滤器使用细节5. Filter的声明周期6. FilterConfig7. 过滤器五种拦截行为 1. Filter 过滤器 2. Filter介绍 3. FilterChain 3. Filter 过滤器的使用 import javax.servlet.ServletExcep…

SQL:group by 的用法及其与 over(partition by)的区别

1.group by的作用 根据一定的规则将一个数据集划分成若干个小区域,然后针对每个区域进行数据处理。即分组查询,一般是和聚合函数配合使用。 重点说明(重要): 如果用Select选择某个字段,那么这个字段要么在G…