Git Stash、Git Merge、Git Rebase、Git Revert

news2025/1/9 11:31:34

GIT 日常使用总结

    • git stash
    • git merge
    • git rebase
    • 将多个commit合并成一个commit
    • git revert
    • 撤销修改
    • 撤销commit 但是不撤销add 的内容
    • 撤销add
    • GIT Rebase 补充说明:


git stash

  • git stash:将修改后的代码存储到本地的一个栈结构,将工作区和暂存区恢复到修改之前,一般在git pull拉取代码失败时使用,可以跨分支使用
  • git stash pop:将stash的代码恢复,该命令会自动将pop的代码与本地代码进行merge
    具体用法:
  • git stash save ‘message’ message为本次保存的说明信息
  • git stash pop stash@{num} 弹出stash的内容,默认弹出最近一次stash的内容,即stash@{0}
  • git stash list列出所有保存的记录列表,数字越小表示保存时间越近
  • git stash apply stash@{num}弹出stash的内容,默认弹出最近一次stash的内容,可重复弹出
  • git stash drop stash@{num}删除某一条stash的内容
  • git stash clear删除所有stash内容
  • 注:git stash pop或者drop后,stash的序号会自动改变

使用场景:当git pull远程分支的代码时,与本地代码有冲突导致失败
操作:

  1. git stash 将修改后的代码存储到本地
  2. git pull拉取远程仓库代码
  3. git stash pop将pop的代码与pull后的代码进行merge
  4. 解决完冲突之后再进行add、commit即可

git merge

  1. git merge用于将指定的commits合并到当前分支
  2. git merge --abort通常在merge合并后有冲突时使用,表示放弃本次合并
    使用场景: 当远程master分支发生了变化,想要将远程master分支上的变化更新到本地开发分支(dev)上的代码
    操作
  3. git checkout master从dev分支切换到master分支
  4. git pull 拉取远程仓库master分支代码至本地master分支
  5. git checkout dev
  6. git merge master合并master分支至dev分支,此时处于dev分支
  • 当在dev分支上开发完成后,需要合并到master分支

将master 分支合并到当前分支:将基准(master)分支合并到当前分支,等同于:git checkout replier-server-api_1-0-54_BRANCH && git merge master

将当前分支合并到基准(master)分支,等同于:git checkout master && git merge replier-server-api_1-0-51_BRANCH
*

git rebase

使用场景
在本地创建一个dev分支进行开发,开发完成后可以提交代码至远程master分支,但是此时远程master已经有了新的提交
操作

  1. git checkout master 切换到本地master分支
  2. git pull 拉取远程master分支最新代码至本地master
  3. git checkout dev
  4. git rebase -i HEAD~n表示将dev分支上的n次commit合并成一个
  5. git rebase master将master分支代码同步到本地,此处需要解决冲突
  6. 解决完冲突之后,执行git add.,再git rebase --continue
  7. git checkout master
  8. git merge dev将本地dev分支内容合并到master分支

将多个commit合并成一个commit

使用场景:
使用git log查看commit提交历史时,想将最近的两个提交85608和0109a合并成一个commit
请添加图片描述

操作:

  1. git rebase -i commitId commitId是不需要合并的commit的hash值(例如倒数第三个)
  • 注意:在执行此命令时,需要确保工作区是干净的,否则就会报如下错误
  • -i 后面的参数是待合并的两个commit 之前的一个commit 的hash 值,和待合并的两个commit 没有关系
  • 确保工作区是干净的可以使用git stash 进行暂存,执行万rebase 之后使用git stash pop 恢复暂存的内容
    在这里插入图片描述
  1. 输入此命令后就会展示以下界面
  • pick 的意思是要会执行这个 commit
  • squash 的意思是这个 commit 会被合并到前一个commit
    输入i进入编辑模式,将a9e3前面的pick改成s或者squash,然后输入:wq保存并退出
  1. 注意:squash 选择最近一次的提交的HASH 值,需要确保这个Hash 前面是有commit 的,比如这里最近一次的提交是85608,则将85608 前面的pick 修改为squash即可

请添加图片描述

  1. 然后进入commit的编辑页面,需要输入合并后的commit的提交信息,操作方式类似于步骤二,至此就完成了commit的合并。commit 的信息可在第一行添加

git revert

  • git revert 撤销某次的提交,此操作不会修改原有的提交记录,而是会新增一条提交记录来抵消某次某次操作
  • git revert 针对普通的commit
  • git revert -m 针对merge的commit
  • git revert 回滚多次的提交,这是一个前开后闭区间,即不包括commit1,但是包括commit2
    使用场景
    在提交了一次携带bug的commit之后,又进行了两次提交,此时想撤销携带bug的那次提交,但是又想保留之后的两次提交,记录下整个的提交记录,就可以使用该指令
    请添加图片描述

例如想撤销 0109a6 那次的提交,同时保留之后的那次 856082 的那次提交,就可以使用git revert 0109a672 ,就会新增一条commit 记录


撤销修改

  • git log:查看提交历史
  • git reflog:查看命令历史,包括撤销修改的命令
  • git checkout – :当文件已经修改但还未存入暂存区(还未add),此命令可撤销工作区的修改
  • git reset HEAD :当文件已经做了修改并且存入暂存区,此命令可以撤销暂存区的修改,将改动放回到工作区
  • git reset --hard :修改的文件已经commit,使用该命令可以撤销commit的修改,将工作区恢复到上一次commit的状态

撤销commit 但是不撤销add 的内容

  • git reset --soft HEAD^
  • https://www.cnblogs.com/lfxiao/p/9378763.html

撤销add

  • git rm ./roi_ltv/script/renew/* --cached

GIT Rebase 补充说明:

  • https://blog.csdn.net/jiangbo721/article/details/95194859

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

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

相关文章

37-Vue之ECharts高级-交互API

交互API前言全局ECharts对象echartsInstance对象前言 本篇来学习下ECharts中交互API的使用 全局ECharts对象 全局 echarts 对象是引入 echarts.js 文件之后就可以直接使用的 init :初始化ECharts实例对象,使用主题 registerTheme:注册主题…

Avatar和虚拟场景如何影响用户VR社交行为

对于VR社交来讲,虚拟场景(社交环境)、Avatar(虚拟化身)是两个重要的元素,一个代表了人们在VR中互动的空间,而另一个则代表他们在这个空间中所扮演的角色。现阶段,Avatar有多种形态&a…

已解决import tensorflow.contrib.layers as layers导包错误

已解决W tensorflow/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library ‘cudart64_110.dll’; dlerror: cudart64_110.dll not found I tensorflow/stream_executor/cuda/cudart_stub.cc:29] Ignore above cudart dlerror if you do not ha…

opencv-python常用函数解析及参数介绍(八)——轮廓与轮廓特征

轮廓与轮廓特征前言1.获取轮廓通过膨胀与腐蚀获得轮廓通过梯度获取轮廓通过边缘检测获取轮廓2.寻找轮廓参数及作用对比3.轮廓特征前言 在前面的文章中我们已经学会了使用膨胀与腐蚀、使用梯度、使用边缘检测的方式获得图像的轮廓,那么在获得轮廓后我们可以对图像进…

​赛分科技冲刺科创板上市:拟募资8亿元,复星、高瓴为股东​

近日,苏州赛分科技股份有限公司(下称“赛分科技”)在上海证券交易所递交招股书,准备在科创板上市。本次冲刺上市,赛分科技计划募资8亿元,将用于20万升/年生物医药分离纯化用辅料、研发中心建设项目&#xf…

《收获,不止Oracle》读书笔记一

当今时代 技术人员,真正的差距其实在意识 1.忽略了知识的重点 20%的知识,解决80%的问题 2.从未考虑知识落地 知识要落地, 要思考应用的场合。 学习任何技术都是一样的,没有思考过你所学的某项技术有什么用,没有想…

P1827 [USACO3.4] 美国血统 American Heritage

题目描述 农夫约翰非常认真地对待他的奶牛们的血统。然而他不是一个真正优秀的记帐员。他把他的奶牛 们的家谱作成二叉树,并且把二叉树以更线性的“树的中序遍历”和“树的前序遍历”的符号加以记录而 不是用图形的方法。 你的任务是在被给予奶牛家谱的“树中序遍历…

计算机网络 | 湖科大教书匠

一、因特网概述 1、网络、互联网和因特网 网络是由若干结点和连接这些结点的链路组成 多个网络还可以通过路由器互联起来,这样就构成了一个覆盖范围更大的网络,互联网 因此,互联网是网络的网络(Network of Networks&#xff0…

hadoop+ranger+kerberos页面权限配置(四)

一、原理介绍 hdfs 指令测试:hdfs dfs -mkdir /ranger 原理:根据路径进行文件夹操作赋权。一旦指定文件夹权限,则该用户可以操作该文件夹及该文件夹底下的子文件夹。 yarn 指令测试:hadoop jar /home/hadoop/module/hadoop-3.2.2…

跨平台数据库管理器DbGate

本文软件由网友 zxc 推荐;隔了很久才开始写,又隔了很久才想起来发 😂 什么是 DbGate ? DbGate 是跨平台的数据库管理器。支持 MySQL、PostgreSQL、SQL Server、MongoDB、SQLite 等的数据库管理器。能够在 Windows、Linux、Mac 下运…

Z函数(扩展KMP)

1,定义 z函数存储字符串s(长度n&#xff0c;下标从0开始&#xff09;与其所有后缀s[i,n-1](0<i<n-1)的最大公共前缀LCP的值&#xff08;一般默认z[0]0,有时是n) 2,思路 叫他扩展KMP是有原因的&#xff0c;因为思想相近&#xff0c;我们求取z[i]&#xff0c;尝试利用前…

20230102单独编译原厂RK3588开发板的开发板rk3588-evb1-lp4-v10的Android12的内核

20230102单独编译原厂RK3588开发板的开发板rk3588-evb1-lp4-v10的Android12的内核 2023/1/2 20:52 《RK3588_Android12_SDK_Developer_Guide_CN.pdf》 原厂的开发板rk3588-evb1-lp4-v10单独编译内核的方式&#xff1a; cd kernel-5.10 export PATH../prebuilts/clang/host/linu…

redis的常见命令

Redis 所有的 key&#xff08;键&#xff09;都是字符串。在谈基础数据结构时&#xff0c;我们讨论的是存储值的数据类型&#xff0c;主要包括常见的 5 种数据类型&#xff0c;分别是&#xff1a;String、List、Set、Zset、Hash 数据结构介绍 Redis 是一个 key-value 的数据库…

Java基础漏洞(一)

最近在复习一些Java基础&#xff0c;填补自己的知识漏洞。 1.转义字符 (1)\t代表的是制表符&#xff0c;\n代表的是空格&#xff0c;\r则代表的是回车 public class Main{public static void main(String[] args) {System.out.println("年龄\t性别\t身高\n18\t男\t183&…

《小猫猫大课堂》4——数组,操作符,常见关键字

更新不易&#xff0c;麻烦多多点赞&#xff0c;欢迎你的提问&#xff0c;感谢你的转发&#xff0c; 最后的最后&#xff0c;关注我&#xff0c;关注我&#xff0c;关注我&#xff0c;你会看到更多有趣的博客哦&#xff01;&#xff01;&#xff01; 喵喵喵&#xff0c;你对我…

十三、网络编程、UDP、TCP协议

JMM(了解) JMM就是Java内存模型(java memory model)。因为在不同的硬件生产商和不同的操作系统下&#xff0c;内存的访问有一定的差异&#xff0c;所以会造成相同的代码运行在不同的系统上会出现各种问题。所以java内存模型(JMM)屏蔽掉各种硬件和操作系统的内存访问差异&#…

python 办公自动后,第一天:创建excel写入数据

1&#xff0c;python第三方模块&#xff1a;xlwt写入excel文件 #pycharm 中安装pip install xlwt #xlwr 用户写入文件模块 #pip install xlwt # pip list 查看安装的模块 # pip install import xlwt#创建excelwb xlwt.Workbook()# 选择工作簿sh wb.add_sheet(第一个sheet页…

LVGL学习笔记11 - 按钮矩阵Button Matrix

目录 1. 构造矩阵 2. Parts 2.1 LV_PART_MAIN 2.2 LV_PART_ITEMS 3. 样式 3.1 按钮大小 3.2 间距 3.3 控制按钮 3.4 控制map 3.5 Check唯一性 4. 事件 4.1 LV_EVENT_VALUE_CHANGED 4.2 LV_EVENT_LONG_PRESSED 4.3 LV_EVENT_DRAW_PART_BEGIN 按钮矩阵是多个按钮的组…

臻图信息搭建土壤墒情监测应用平台,推进现代农业信息化发展

“十四五”期间&#xff0c;国家高度重视土壤生态环境监测等问题&#xff0c;先后出台了一系列规范性文件&#xff0c;为我国土壤防治领域建立了一套标准、导则、指南和管理等解决对策&#xff0c;使我国土壤修复法律法规和标准化建设呈现出系列化和系统化趋势&#xff0c;有效…

计算机视觉实战-----pytorch官方demo(Lenet网络)实现

系列文章目录 文章目录系列文章目录前言零、环境搭建一、下载CIFAR10数据集二、测试图片三、模型搭建四、开始train五、测试六、tensorboard可视化总结前言 通过一个官方列子&#xff0c;清楚深度学习中图像的训练的整个流程 零、环境搭建 pycharm下载&#xff1a;pycharm官网…