GIT版本管理与分支控制

news2024/9/9 7:29:58

目录

1、了解Git功能

2、第一次使用Git(首次配置好,后续不用再操作)

打开git后端

设置用户签名

结果

3、初始项目架构

创建本地新仓库并初始化

文件添加到本地仓库

a.文件添加缓存区

b.缓存区内容提交到本地仓库

c.改写提交的注释

4、提交修改与版本回滚

commit修改内容

版本回滚(后悔药!)

简单操作

高级操作

5、处理分支

为什么要引入分支

创建分支

a.手动操作

b.代码操作

切换分支

a.手动操作

b.代码操作

合并分支

a.手动操作

b.代码操作

查看分支

删除分支

本地分支

删除远程分支(可能需要权限)

6、查看日志

查看历史提交日志

查看提交历史


1、了解Git功能

  • Git是分布式版本控制工具
  • 分布式表示每个人的电脑都是服务器,客户端可以代码仓库的完整镜像
  • 版本控制表示随时通过提交,记录项目内容变化,并随时能切换到变化前内容
  • 工作机制如图

2、第一次使用Git(首次配置好,后续不用再操作)

打开git后端

找到对应文件夹下,鼠标右键 选择open git bash here,打开界面如下

设置用户签名

git config --global user.name 你的名字   
git config --global user.email 你的邮箱

结果

3、初始项目架构

创建本地新仓库并初始化

  • 右键new 文件夹或者mkdir指令创建
  • 进入该文件夹目录中
  • git init 初始化仓库

初始化成功如图:

文件添加到本地仓库

a.文件添加缓存区

git add 文件名

b.缓存区内容提交到本地仓库

git commit -m “提交操作的注释”

c.改写提交的注释

git commit --amend

进入到vim编译器

选择  Y  后看到注释信息

按下"i"进入编辑,修改完成按下ctrl+o(这个是英文o),最后ctrl+x退出

4、提交修改与版本回滚

每次修改commit后都有一个版本记录,箭头指向为此版本号(回滚就是利用此id)

黄书签图案:当前版本位置

绿书签图案:本地仓库的master所处版本位置

Android Studio 、IDEA等系列软件通用操作

commit修改内容

系统自带提交,点击边框commit,进入提交暂存界面

选择需要提交的changes,再点击左下角的commit

版本回滚(后悔药!)

简单操作

a.最好自己在本地数据库回滚

b.鼠标左键选中对应版本,右键选择checkout Revision

注意:当前版本A存在未commit修改,最好选择Force checkout

  • Force checkout 强制切换,切换到版本B时,暂存区是独立的,切换会版本A时会恢复原暂存区
  • Smart Checkout 让你自己选择在二者不同的地方修改后再跳转版本B
  • Don't Checkout 放弃回滚

结果:黄色书签(当前版本)会跳到分支B,绿色书签(master)仍然在原位置

高级操作

git reset --soft 版本id           :  仅仅头指针恢复,add暂存区和工作空间内容不变

git reset --mixed 版本id       :头指针和add暂存区恢复,工作空间内容不变

git reset --hard 版本id       : 一切全部恢复    (我们常用!!!)

推送修改到远程数据库

常用语句:git push origin HEAD:refs/for/master

git push orgin HEAD:refs/for/目标分支

5、处理分支

为什么要引入分支

  • 克隆整个master
  • 同时进行多个功能开发
  • 各个分支开发失败,删除即可,不会对其他分支造成影响
  • 开发成功合并到master分支即可

创建分支

a.手动操作

选中master后右键,选择New Branch From "master" -> 勾选checkout branch ,取好分支名

自动生成并跳转到新分支,名字是你刚才取得,内容是master直接拷贝一份过去(一模一样)

b.代码操作

在Terminal终端输入如下指令

git branch 分支名 //创建分支
git checkout 分支名 //跳转到该分支

//创建该新分支并跳转
git checkout -b 分支名

切换分支

a.手动操作

选中该分支 ,右键checkout

b.代码操作

终端中 ---》 git checkout 分支名

合并分支

a.手动操作

切换到master分支后,选中待合并分支,右键选择merge "待合并分支名"  into "master"

b.代码操作

进入Terminal后,checkout切换到master分支,输入下面指令

git merge 分支名

查看分支

git branch -a 或者直接在Git模块查看

删除分支

本地分支

git branch -D 分支名   或者先切换到其他分支,然后选中待删除分支,右键点击Delete

删除远程分支(可能需要权限)

git push origin --delete 远程分支名 或者 选中然后右键点击Delete

6、查看日志

查看历史提交日志

git log

  • commit 后是这次提交的版本id (括号内表示头指针位置)
  • Anthor 提交者和邮箱
  • Date 提交时间
  • 下面是提交的注释

查看提交历史

git reflog

包括仓库版本提交和回滚版本操作

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

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

相关文章

Miniconda快速安装conda

关注B站可以观看更多实战教学视频:hallo128的个人空间 安装官方网址:https://docs.anaconda.com/miniconda/#quick-command-line-install 1. Miniconda for Windows curl https://repo.anaconda.com/miniconda/Miniconda3-latest-Windows-x86_64.exe -o …

Python酷库之旅-第三方库Pandas(048)

目录 一、用法精讲 171、pandas.Series.nlargest方法 171-1、语法 171-2、参数 171-3、功能 171-4、返回值 171-5、说明 171-6、用法 171-6-1、数据准备 171-6-2、代码示例 171-6-3、结果输出 172、pandas.Series.nsmallest方法 172-1、语法 172-2、参数 172-3、…

刷新历史新高后又大跌!剖析黄金现在适合投资吗?

近期现货黄金价格的波动再度受到世界投资者的瞩目,先是七月上旬受美国CPI数据走弱、美联储降息预期增强等因素的影响,金价出现了十分强势的上涨,而且刷新历史高点2482。但从七月下旬开始,市场开始消化降息的预期,并且部…

Kimi与AiPPT合作:一键生成PPT的新体验

Kimi AiPPT 又是一次强强联手!这次 Kimi 与 AiPPT 达成协作,作为国内领先的智能助手和宏大的PPT制作平台,两者携手推出的一键生成PPT功能。这次合作直接合并了双方各自的优势,通过“一键生成PPT”的创新服务,极大地提…

昇思25天学习打卡营第20天|ShuffleNet 图像分类案例:模块、训练与评估

目录 基于 MindSpore 的分组卷积类定义与实现 基于 MindSpore 的 ShuffleV1Block 类定义与数据处理 基于 MindSpore 的 ShuffleNetV1 网络定义与构建 Cifar-10 数据集的获取、预处理与分批操作 基于 ShuffleNetV1 模型在 CPU 上的训练配置与执行 ShuffleNetV1 模型在 CPU …

【神器分享】自从用了这个神器,大规模RNA-seq数据挖掘我也可以

咱不来虚的,只分享干货,不谈枯燥的理论,只来通俗易懂的操作。先来看一张图: 通过这张图展示的是 GEO数据库中的 RNA-seq数据与芯片数据积累随时间的变化,很显然测序数据从2015年开始就已经超过了芯片数据的累积 &#…

EtherCAT运动控制器上位机之Python+Qt(一):链接与单轴运动

ZMC408CE硬件介绍 ZMC408CE是正运动推出的一款多轴高性能EtherCAT总线运动控制器,具有EtherCAT、EtherNET、RS232、CAN和U盘等通讯接口,ZMC系列运动控制器可应用于各种需要脱机或联机运行的场合。 ZMC408CE支持8轴运动控制,最多可扩展至32轴…

AI初学者必看: 什么是大型语言模型 (LLM)?

介绍 “人工智能(AI)”一词于 1956 年问世,如今已为大家所熟知。然而,在 ChatGPT 迅速流行之前,AI 的使用和讨论大多局限于科学研究或虚构电影。如今,AI 尤其是生成式 AI 已成为大家热议的话题。 初学者生…

使用Process Explorer和Dependency Walker排查dll动态库加载失败的问题

目录 1、问题描述 2、如何调试Release版本的代码? 3、使用Process Explorer查看exe主程序加载的dll库列表,发现mediaplay.dll没有加载起来 4、使用Dependency Walker查看rtcmpdll.dll的库依赖关系和接口调用情况,定位问题 4.1、使用Depe…

html+css+js 实现3D透视倾斜按钮,javascript库之vanilla-tilt.js详解

前言:哈喽,大家好,今天给大家分享htmlcss 绚丽效果!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏关注哦 💕 文…

常用游戏运行库 v4 官方版下载与安装教程 (游戏DLL补全包)

前言 游戏运行库包含了VC运行库合集,.NET2.0到.NET4.8合集,DirectX9.0 Rapture3D 等游戏必备的系统组件,如果你的游戏安装后无法运行,那么安装这些组件基本上就可以解决。本必备运行库安装包集成32位和64位运行库,是目…

(自用)MyLog 简单日志 .net6.0 等

appsettings.json {"LogOnOff": true //true 开启日志&#xff1b;false 关闭日志 } MyLog.cs using System.ComponentModel;namespace Namespace {/// <summary>/// 日志类型 枚举/// </summary>public enum LogType{[Description("调试日志&q…

Android经典面试题之实战经验分享:如何简单实现App的前后台监听判断

本文首发于公众号“AntDream”&#xff0c;欢迎微信搜索“AntDream”或扫描文章底部二维码关注&#xff0c;和我一起每天进步一点点 在Android中判断一个应用是否处于前台或后台&#xff0c;可以使用ActivityLifecycleCallbacks 和 ProcessLifecycleOwner。在Kotlin中&#xff…

实验2-5-3 求平方根序列前N项和

//实验2-5-3 求平方根序列前N项和/*本题要求编写程序&#xff0c; 计算平方根序列123⋯的前N项之和。 可包含头文件math.h&#xff0c;并调用sqrt函数求平方根。*/#include<stdio.h> #include<math.h> int main(){int n0;scanf("%d",&n);//输入Nint …

【Canvas与艺术】三环莫比乌斯圈

【成图】 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>三环莫比乌斯圈</title><style type"text/css"&g…

测桃花运(算姻缘)的网站系统源码

简介&#xff1a; 站长安装本源码后只要有人在线测算&#xff0c;就可以获得收入哦。是目前市面上最火的变现利器。 本版本无后台&#xff0c;无数据。本版本为开发的逗号联盟接口版本。直接对接逗号联盟&#xff0c;修改ID就可以直接运营收费赚钱。 安装环境&#xff1a;PH…

可以个性化的网盘与相册服务 PDS

可以个性化的网盘与相册服务 PDS 什么是PDS企业版企业网盘团队管理用户管理安全策略企业设置文件设置及其他设置专属登录配置 使用建议企业网盘用户端开发者版体验感受 什么是PDS 在正式开始测评PDS之前&#xff0c;首先来了解一下什么是PDS。PDS 网盘与相册服务&#xff08;D…

Pythonic 的从远程列表中提取分支名称方法

1、问题背景 在 Git 版本控制系统中&#xff0c;我们需要经常使用 git ls-remote 命令来获取远程仓库的分支列表。 这个命令的输出通常包含分支的哈希值和分支名称&#xff0c;就像这样&#xff1a; db6ad7246abf74cb845baa60e6fe45dacf897612 HEAD 1fc347b17201054d8b5b9…

YOLOv8 基于BN层的通道剪枝

YOLOv8 基于BN层的通道剪枝 1. 稀疏约束训练 在损失项中增加对BN层的缩放系数 γ \gamma γ和偏置项 β \beta β的稀疏约束&#xff0c; λ \lambda λ系数越大&#xff0c;稀疏约束越严重 L ∑ ( x , y ) l ( f ( x ) , y ) λ 1 ∑ γ g ( γ ) λ 2 ∑ β g ( β ) L…

华杉研发九学习日记18 集合 泛型

华杉研发九学习日记18 一&#xff0c;集合框架 1.1 集合和数组的区别 集合就是在java中用来保存多个对象的容器 集合是数组的升级版&#xff0c;集合中只能放置对象[object]. 数组: 在java中用来保存多个具有相同数据类型数据的容器 数组弊端&#xff1a; 1.数组只能保存…