分布式版本控制工具 git

git 是什么

  • 分布式版本控制工具
  • github 是代码托管平台。

git 有什么用

  • 保存文件的所有修改记录。
  • 使用版本号(sha1 哈希值) 进行区分。
  • 随时可浏览历史版本记录。
  • 可还原到历史指定版本。
  • 对比不同版本的文件差异。

为什么要使用 git

  • 多人协作开发一个大型项目。
  • 每个人都在代码库下载代码,然后进行修改,把大家不同版本的代码合在一起上传到平台。
  • 公司都会有自己的代码托管平台。

git 基本概念

  • 仓库:
    • 远程仓库:git init --bare 创建一个裸仓库。
    • 本地仓库:git clone ... 克隆远程仓库到本地。
  • 协议:
    • http / https
    • ssh
      • ssh 协议是一个验证授权的网络协议。
      • 使用 ssh 公钥登录 git 服务器。
        • 生成公钥和私钥ssh-keygen -t rsa
        • 安装 openssh server(可省略)。
        • 复制公钥内容到远端服务器 .ssh/authorized_keys
        • git clone ssh://root@123.249.112.139:/root/holo_render/remote_storage
  • 配置用户名和邮箱:
    • 局部配置:
      git config user.name zcoder
      git config user.email zcoder@163.com
      
    • 全局配置:
      git config --global user.name zcoder
      git config --global user.email zcoder@163.com
      
  • 版本号:40sha1 哈希值。
  • head:当前检出记录的符号引用。

请添加图片描述


git 基本操作

  • 暂存:git add
  • 提交:git commit
  • 推送:git push
  • 拉取:git fetch将远程仓库所包含分支的最新 commit-id 记录到本地文件
  • 拉取合并:git pullgit fetch + git merge
  • 查看状态:git status
  • 查看历史:git log

git 逆向操作

  • 暂存区 → 本地工作区:git restore -S
  • 本地仓库 → 暂存区:git reset --soft
  • 本地仓库 → 本地工作区:git reset --mixed
  • 本地仓库 → nullgit reset --hard

git 本地仓库整理操作

  • 整理上一次提交:git commit --amend → 相同功能多次提交复用上次提交信息。
  • 整理多次提交:git rebase -i hash1 hash2(左开右关)。
  • 只在私有仓库,也就是在 develop 分支上使用,因为提交的 commit-id 会发生变化。

git 分支操作

  • 查看分支:git branch
  • 创建分支:
    • git branch develop → 创建
    • git switch develop → 切换
    • git checkout -b develop → 创建并切换。
  • 删除分支:git branch -d develop
  • 合并分支:
    • 切换到本地 master 分支,拉取远程仓库 master 最新数据。
      git switch master
      git pull
      
    • 切换到 develop 分支,把本地 master 合并到 develop
      git switch develop
      git merge master 
      
    • 如果有冲突要解决冲突,测试代码,没问题的话就提交。
      vi api.hpp
      git add .
      git commit -m "fix:merge master"
      
    • 切换到本地 master 分支,把 develop 合并到本地 master,最后提交到远程仓库。
      git switch master
      git merge develop
      git push origin master
      

git 解决冲突

  • 冲突产生原因:不同分支修改了同一文件的同一行或者相邻行
  • 解决原则:
    • 不要影响其他人提交的功能,也不能破坏自己提交的功能。
    • 协商解决。
  • 解决方式:git merge
  • 建议:提交前先 git pull 拉取最新代码。

请添加图片描述


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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C# 结合 JS 暴改腾讯 IM SDK Demo

目录 关于腾讯 IM SDK Demo 范例运行环境 设计思路 服务端生成地址 IM 服务端接收 IM 客户端程序 小结 关于腾讯 IM SDK Demo 腾讯云即时通信 IM SDK 提供了单聊、群聊、关系链、消息漫游、群组管理、资料管理、直播弹幕等功能,并提供完备的 App 接入及管…

【STM32CubeIDE】软件硬件SPI+六针OLED使用

前言 本文将介绍STM32 6针OLED的使用,分别使用软件和硬件两种SPI驱动方式,最终实现OLED显示TEST-ok字符和数字累加刷新显示 软件平台:STM32CubeIDEHAL库 硬件:STM32F103ZET6(正点原子战舰V3)六针OLED 题外话: 最…

开源博客项目Blog .NET Core源码学习(26:App.Hosting项目结构分析-14)

后台管理页面的系统管理下主要包括用户管理、角色管理、按钮管理和菜单管理,其中创建用户时要指定角色,创建角色时需指定菜单权限,按钮管理也是基于各菜单项进行设置,只有菜单管理相对独立,因此本文学习并分析App.Host…

【Python搞定车载自动化测试】——Python基于Pytest框架实现UDS诊断自动化(含Python源码)

系列文章目录 【Python搞定车载自动化测试】系列文章目录汇总 文章目录 系列文章目录💯💯💯 前言💯💯💯一、环境搭建1.软件环境2.硬件环境 二、目录结构三、源码展示1.诊断基础函数方法2.诊断业务函数方法…

基于Keras的手写数字识别(附源码)

目录 引言 为什么要创建虚拟环境,好处在哪里? 源码 我修改的部分 调用本地数据 修改第二层卷积层 引言 本文是博主为了记录一个好的开源代码而写,下面是代码出处!强烈建议收藏!【深度学习实战—1】&#xff1a…

SK6812-RGBW是一个集控制电路与发光电路于一体的智能外控LED光源

产品概述: SK6812-RGBW是一个集控制电路与发光电路于一体的智能外控LED光源。其外型与一个5050LED灯珠相同,每个元件即为一个像素点。像素点内部包含了智能数字接口数据锁存信号整形放大驱动电路,电源稳压电路,内置恒流电路&#xff0…

基于51单片机的盆栽自动浇花系统

一.硬件方案 工作原理是湿度传感器将采集到的数据直接传送到ADC0832的IN端作为输入的模拟信号。选用湿度传感器和AD转换,电路内部包含有湿度采集、AD转换、单片机译码显示等功能。单片机需要采集数据时,发出指令启动A/D转换器工作,ADC0832根…

WordPress Country State City Dropdown CF7插件 SQL注入漏洞复现(CVE-2024-3495)

0x01 产品简介 Country State City Dropdown CF7插件是一个功能强大、易于使用的WordPress插件,它为用户在联系表单中提供国家、州/省和城市的三级下拉菜单功能,帮助用户更准确地填写地区信息。同时,插件的团队和支持也非常出色,为用户提供高质量的服务。 0x02 漏洞概述 …

零基础的粉丝有福了:逐键提示盲打更轻松

盲打就是不看键盘去打字,对于零基础的粉丝而言,盲打入门通常都是很难的,今天就给大家放个福利:从今天开始就能盲打,3天之后盲打就入门了。 真的有这么简单吗?是的,跟着我做就可以了。 首先&am…

结构体(位段)内存分配

结构体由多个数据类型的成员组成。那编译器分配的内存是不是所有成员的字节数总和呢? 首先,stu的内存大小并不为29个字节,即证明结构体内存不是所有成员的字节数和。   其次,stu成员中sex的内存位置不在21,即可推测…

Linux驱动开发笔记(二) 基于字符设备驱动的I/O操作

文章目录 前言一、设备驱动的作用与本质1. 驱动的作用2. 有无操作系统的区别 二、内存管理单元MMU三、相关函数1. ioremap( )2. iounmap( )3. class_create( )4. class_destroy( ) 四、GPIO的基本知识1. GPIO的寄存器进行读写操作流程2. 引脚复用2. 定义GPIO寄存器物理地址 五、…

视频汇聚平台LntonCVS视频监控系统前端错误日志记录及Debug模式详细讲解

LntonCVS作为一种支持GB28181标准的流媒体服务平台,旨在提供一个能够整合不同厂商设备、便于管理和扩展的解决方案,以适应日益复杂的视频监控环境。通过实现设备的统一管理和流媒体的高效传输,LntonCVS帮助构建更加灵活和强大的视频监控系统。…

Andoird使用Room实现持久化及使用Room进行增删查改

文章目录 Room概述Room的使用一、在gradle.build中添加依赖库kotlinJava 创建实体类创建抽象Dao层接口创建DataBase层使用创建的查看数据库 总结: 这篇文章会告诉你如何在Android中通过kotlin或者Java来实现数据持久化 Room概述 处理大量结构化数据的应用可极大地受…

强烈推荐 20.7k Star!企业级商城开源项目强烈推荐!基于DDD领域驱动设计模型,助您快速掌握技术奥秘,实现业务快速增长

更多资源请关注纽扣编程微信公众号 1 项目简介 商城是个从零到一的C端商城项目,包含商城核心业务和基础架构两大模块,推出用户、消息、商品、订单、优惠券、支付、网关、购物车等业务模块,通过商城系统中复杂场景,给出对应解决方案。使用 …

Java——简易图书管理系统

本文使用 Java 实现一个简易图书管理系统 一、思路 简易图书管理系统说白了其实就是 用户 与 图书 这两个对象之间的交互 书的属性有 书名 作者 类型 价格 借阅状态 而用户可以分为 普通用户 管理员 使用数组将书统一管理起来 用户对这个数组进行操作 普通用户可以进…

Axure RP 10汉化版修改文字

效果 安装目录 lang/default Axure 10 RP 汉化包(概览改图层)

Express 的 req 和 res 对象

新建 learn-express文件夹,执行命令行 npm init -y npm install express 新建 index.js const express require(express); const app express();app.get(/, (req, res, next) > {res.json(return get) })app.post(/, (req, res, next) > {res.json(retur…

单机一天轻松300+ 最新微信小程序拼多多+京东全自动掘金项目、

现代互联网经济的发展带来了新型的盈利方式,这种方法通过微信小程序的拼多多和京东进行商品自动巡视,以此给商家带来增加的流量,同时为使用者带来利润。实践这一手段无需复杂操作,用户仅需启动相应程序,商品信息便会被…

【东山派Vision K510开发板试用笔记】WiFi配网问题

目录 概述 WiFi配网的修改 悬而未决的问题 概述 最近试用了百问网提供的东山派Vision开发板,DongshanPI-Vision开发板是百问网针对AI应用开发设计出来的一个RSIC-V架构的AI开发板,主要用于学习使用嘉楠的K510芯片进行Linux项目开发和嵌入式AI应用开发…

闲话 .NET(5):.NET Core 有什么优势?

前言 .NET Core 并不是 .NET FrameWork 的升级版,它是一个为满足新一代的软件设计要求而从头重新开发的开发框架和平台,所以它没有 .NET FrameWork 的历史包袱,相对于 .NET FrameWork,它具备很多优势。 .NET Core 有哪些优势&am…