GIT技巧

news2025/1/22 9:26:31

目录

基础命令

commit 、branch

merge

rebase

高级特性

自由修改提交树

cherry-pick

rebase

远程仓库命令


基础命令

commit 、branch

Git Commit
Git 仓库中的提交记录保存的是你的目录下所有文件的快照,就像是把整个目录复制,然后再粘贴一样,但比复制粘贴优雅许多!
Git 希望提交记录尽可能地轻量,因此在你每次进行提交时,它并不会盲目地复制整个目录。条件允许的情况下,它会将当前版本与仓库中的上一个版本进行对比,并把所有的差异打包到一起作为一个提交记录。
Git 还保存了提交的历史记录。这也是为什么大多数提交记录的上面都有父节点的原因。对于项目组的成员来说,维护提交历史对大家都有好处。你可以把提交记录看作是项目的快照。提交记录非常轻量,可以快速地在这些提交记录之间切换。

Git Branch
Git 的分支也非常轻量。它们只是简单地指向某个提交纪录 - 仅此而已。所以许多Git 爱好者传颂:
早建分支!多用分支!
这是因为即使创建再多的分支也不会造成储存或内存上的开销,并且按逻辑分解工作到不同的分支要比维护那些特别臃肿的分支简单多了。
在将分支和提交记录结合起来后,使用分支其实就相当于在说:“我想基于这个提交以及它所有的父提交进行新的工作。

merge

分支与合并
我们新建一个分支,在其上开发某个新功能,开发完成后再合并回主线。在 Git 中合并两个分支时会产生一个特殊的提交记录,它有两个父节点。翻译成自然语言相当于:“我要把这两个父节点本身及它们所有的祖先都包含进来。”

 

rebase

git rebase
Rebase 实际上就是取出一系列的提交记录,“复制”它们,然后在另外一个地方逐个放下去,
Rebase的优势就是可以创造更线性的提交历史。如果只允许使用 Rebase的话,代码库的提交历
史将会变得异常清晰。

 在开发社区里,有许多关于merge 与rebase 的讨论。以下是关于rebase的优缺点:
优点:Rebase 使你的提交树变得很干净,所有的提交都在一条线上
缺点:Rebase 修改了提交树的历史
比如,提交C1 可以被 rebase 到C3 之后。这看起来C1 中的工作是在C3 之后进行的,但实际上是在 C3 之前。
一些开发人员喜欢保留提交历史,因此更偏爱menge。而其他人(比如我自己)可能更喜欢干净的提交树。于是偏爱rebase。仁者见仁,智者见智。

高级特性

HEAD是一个对当前检出记录的符号引用,也就是指向你正在其基础上进行工作的提交记录。
HEAD总是指向当前分支上最近一次提交记录。大多数修改提交树的Git命令都是从改变HEAD的指向开始的。
HEAD通常情况下是指向分支名的(如bugFix)。在你提交时,改变了 bugFix的状态,这一变化通过 HEAD变得可见。
分离的 HEAD就是让其指向了某个具体的提交记录而不是分支名。
HEAD -> main-> C1  HEAD指向 main, main 指向 C1
checkout C1后变成了HEAD -> C1

通过哈希值指定提交记录很不方便,所以Git引入了相对引用。使用相对引用的话,你就可以从一个易于记忆的地方(比如bugFix分支或HEAD)开始计算。相对引用非常给力,这里我介绍两个简单的用法:
·使用^向上移动 1 个提交记录,如git checkout main^
·使用~<num>向上移动多个提交记录,如~3

强制修改分支位置
可以直接使用选项让分支指向另一个提交。例如:
git branch -f main head~3
上面的命令会将 main 分支强制指向 HEAD的第3级父提交。

撒销变更
在Git 里撤销变更的方法很多。和提交一样,撤销变更由底层部分(暂存区的独立文件或者片段)和上层部分(变更到底是通过哪种方式被撤销的)组成。主要有两种方法用来撤销变更:
git reset 通过把分支记录回退几个提交记录来实现撤销改动。你可以将这想象成“改写历史”。git reset 向上移动分支,原来指向的提交记录就跟从来没有提交过一样。(在reset后,所做的变更还在,但是处于未加入暂存区状态。)

git  reset   head~1

 虽然本地分支使用reset很方便,但对远程分支是无效的;为了撤销更改并分享给别人,需要用revert

奇怪!在我们要撤销的提交记录后面居然多了一个新提交!
这是因为新提交记录c2'引入了更改,这些更改刚好是用来撤销c2这个提交的。也就是说c2'的状态与c1是相同的,revert 之后就可以把你的更改推送到远程仓库与别人分享啦。

git revert head

自由修改提交树

上面的这些概念涵盖了 Git 98% 的功能,同样也足够满足开发者的日常需求,然而,剩余的 10% 在处理复杂的工作流时(或者当你陷入困惑时)可能就显得尤为重要了。接下来要讨论的这个话题是“整理提交记录”— 开发人员有时会说“我想要把这个提交放到这里,那个提交放到刚才那个提交的后面”,而接下来就讲的就是它的实现方式,

cherry-pick

本系列的第一个命令形式为:git cherry-pick <提交号>
如果你想将一些提交复制到当前所在的位置(head)下面的话,Cherry-pick 是最直接的方式了。

如下将side分支上的C2,C4提交记录复制到main分支

git  cherry-pick  C2  C4

 

rebase

如果你不清楚你想要的提交记录的哈希值呢?幸好Git 帮你想到了这一点,我们可以利用交互式的rebase—如果你想从一系列的提交记录中找到想要的记录,这就是最好的方法了

交互式rebase 指的是使用带参数-interactive的rebase 命令,简写为-i,如果你在命令后增加了这个选项,Git 会打开一个 UI 界面并列出将要被复制到目标分支的备选提交记录,它还会显示每个
提交记录的哈希值和提交说明,提交说明有助于你理解这个提交进行了哪些更改。在实际使用时,所谓的UI 窗口一般会在文本编辑器 — 如Vim- 中打开一个文件。 

git rebase -i head~4

tags

分支很容易被人为移动,有新提交时也很容易改变,有没有可以永远指向某个提交记录的标识呢,比如软件发布新的大版本,或修正一些重要的bug,或增加了某些新特性。tag可以永久的将某个特定的提交命名为里程碑,他不会随着新提交移动,也不能切换到某个标签上进行修改提交,他就像是提交树上的一个锚点,标识了某个特定的位置

git  tag  v1  c1

远程仓库命令

远程仓库是一个强大的备份,也能让代码社交化

远程分支命名规范 <remote name>/<branch name> 比如origin/main

git pull=git fetch;git merge

git pull --rebase=git fetch;git rebase

git clone #在本地创建一个远程仓库的拷贝

git fetch #从远程仓库下载本地仓库缺失的提交记录并更新远程分支指针origin/main,但并不会改变本地仓库的状态,不会更新本地main分支,也不会修改磁盘上的文件

git pull #抓取更新并合并到本地分支

git push #将变更上传到远程并在远程仓库上合并你的新提交记录

git branch -u origin/main foo #设置foo跟踪远程分支

git push origin 源:目的地

git fetch origin 源:目的地

git push origin :foo #删除远程foo分支

git fetch origin :bar #在本地创建一个新分支

git pull origin main:foo #本地创建foo,拉取远程main合并到本地foo,然后再merge到当前检出的分支,参考下图

 

 

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

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

相关文章

Linux内核中ideapad-laptop.c文件全解析6

接前一篇文章《Linux内核中ideapad-laptop.c文件全解析5》&#xff0c;地址为&#xff1a; Linux内核中ideapad-laptop.c文件全解析5_蓝天居士的博客-CSDN博客 上一篇详细分析了ideapad_debugfs_init&#xff0c;本篇详细分析ideapad_input_init。 ideapad_input_init ideap…

Word控件Spire.Doc 【图像形状】教程(7): 如何使用 C# 在 Word 中替换图像

Spire.Doc for .NET是一款专门对 Word 文档进行操作的 .NET 类库。在于帮助开发人员无需安装 Microsoft Word情况下&#xff0c;轻松快捷高效地创建、编辑、转换和打印 Microsoft Word 文档。拥有近10年专业开发经验Spire系列办公文档开发工具&#xff0c;专注于创建、编辑、转…

b站黑马JavaScript的Ajax案例代码——聊天机器人案例

目录 目标效果&#xff1a; 更换的新接口&#xff1a; 1.机器人智能回复接口&#xff1a;http://www.liulongbin.top:3006/api/robot 2.机器人语音接口&#xff1a;http://www.liulongbin.top:3006/api/synthesize 重点原理&#xff1a; 1.jQuery中trim方法 2.jquery中a…

Hive数据查询语言-DQL-含示例演练(Select查询数据、Join查询)

文章目录1. Select查询数据1.1 基础语法1.1.1 select_ecpr1.1.2 ALL、DISTINCT1.1.3 WHERE1.1.4 分区查询、分区裁剪1.1.5 GROUP BY1.1.6 HAVING1.1.7 LIMIT1.1.8 执行顺序1.2 高阶语法1.2.1 ORDER BY1.2.2 CLUSTER BY1.2.4 Union联合查询1.2.5 from子查询&#xff08;Subqueri…

Allegro自动沿着目标任意形状走线操作指导

Allegro自动沿着目标任意形状走线操作指导 Allegro有个非常好用的功能,支持自动沿着目标任意形状走线,对于异形板框走线尤其方便,以下图为例,需要沿着这个外形走一段线 具体操作如下 点击add connect命令 点击空白处 鼠标右击选择contour命令 出现一个对话框,当前是…

03【Spring AOP、CGBLIB代理】

文章目录03【Spring AOP、CGBLIB代理】一、AOP前奏1.1 案例1.1.1 需求设计1.1.2 需求修改1.1.3 需求增加1.1.4 分析存在的问题1.2 动态代理1.2.1 定义接口&#xff1a;1.2.2 日志代理类1.2.3 缓存代理类&#xff1a;1.2.4 测试类二、AOP2.1 AOP 概述2.1.1 纵向编程2.1.2 纵横配…

【Java进阶篇】第六章 IO流

文章目录一、IO流的概述1、流2、流的分类3、Java IO流的四大块4、流的两大特性5、java.io包下的16个常用流二、文件专属流1、java.io.FileInputStream2、java.io.FileOutputStream3、java.io.FileReader4、java.io.FileWriter三、缓冲流与转换流1、java.io.BufferedReader2、ja…

【面试题】深度解析Java多线程中的 run() 与 start() 有什么区别?

【面试题】深度解析Java多线程中的 run() 与 start() 有什么区别&#xff1f; 大多数人的回答 start() run() 深入底层源码的解析 run() 与 start() 为什么我们不能直接调用 run() 方法&#xff1f; 如何证明 start() 会调用 run() 方法&#xff1f; JVM -> OS执行全…

Nodejs -- 数据库基本概念的介绍及在Express中操作数据库

文章目录1. 数据库的基本概念1.1 什么是数据库1.2 常见的数据库及分类1.3 传统型数据库的数据组织结构1.3.1 Excel的数据组织结构1.3.2 传统型数据库的数据组织结构1.3.3 实际开发中库、表、行、字段的关系2. 在Express中操作MySQL2.1 在项目中操作数据库的步骤2.2 安装与配置m…

Java编程案例:买飞机票

编程案例&#xff1a; 一、目的 复习前半段课程学习的Java编程知识&#xff0c;能够使用所学的知识解决问题&#xff0c;提升同学们的编程能力。 二、涉及到的知识点 变量、数组。运算符&#xff1a;基本运算符、关系运算符、逻辑运算符…程序流程控制&#xff1a;if、switc…

np.meshgrid()函数

文章目录(1)自己理解(2)官方解释(3)参数:3.1 x1, x2,…, xn:array_like3.2 sparse:bool, optional 默认false3.3 copy:bool, optional(1)自己理解 np.meshgrid(a, b,indexing "xy") 函数会返回 b.shape() 行 &#xff0c;a.shape() 列的二维数组。 因此 i, j 都是 …

【序列召回推荐】(task6)多兴趣召回Comirec-SA

note Comirec-SA基于attention的多兴趣建模&#xff0c;论文中先通过attention提取单一兴趣&#xff0c;再推广到多兴趣建模。另外使用贪心算法优化带有准确度多样性的目标函数。DR把MIND的attention换成argmax&#xff08;还有初始化方式不同、序列胶囊到兴趣胶囊用可学习权重…

2.线性代数基础

1.矩阵 2. 特殊矩阵 正交矩阵 AATE&#xff08;E为单位矩阵&#xff0c;AT表示“矩阵A的转置矩阵”。&#xff09;或ATAE&#xff0c;则n阶实矩阵A称为正交矩阵 正交矩阵有如下性质&#xff1a; A是正交矩阵&#xff0c;AT也是正交矩阵A的各行是单位向量且两两正交&#xff0…

html实现ezuikit.js萤石云直播监控,ezuikit.js实时监控实现,萤石云实时监控简单实现

效果图 实现 下面的播放url获取&#xff1a;登录萤石云->控制台->我的资源->设备列表->列表中&#xff1a;查看通道->监控地址 appKey和appSecret获取&#xff1a;登录萤石云->控制台->我的账号->应用信息->右侧&#xff1a;应用密钥 下载ezuikit…

(服务器客户端)网络通信是怎么实现的?7000字爆肝----原来java网络编程技术功不可没(多线程,URL,InetAddressm,TCP,UDP)集结

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 秩沅 原创 收录于专栏 java ⭐java网络编程技术⭐ 文章目录⭐java网络编程技术⭐&#x1f468;‍&#x1f4bb;一&#xff0c;URL类…

[附源码]Python计算机毕业设计Django的4s店车辆管理系统

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

虎牙、斗鱼同道同命:共同御寒

配图来自Canva可画 回顾游戏直播行业过去十年&#xff0c;先是直播行业野蛮发展玩家快速跑马圈地&#xff0c;而后历经千播大战形成斗鱼、虎牙分天下的市场格局&#xff0c;现在头部平台进入精细化、多元化运作阶段&#xff0c;市场竞争愈加激烈。 也就是说&#xff0c;游戏直…

4G DTU能装4G物联网卡吗?

科技的发展日新月异&#xff0c;我们国家的发展战略也是支持高新科技公司的发展&#xff0c;所以越来越多的高新科技公司出现&#xff0c;但凡是高新科技公司&#xff0c;在设备的联网中&#xff0c;都会用到物联卡&#xff0c;所以物联卡的市场也愈发火爆&#xff0c;那么今天…

食物链【并查集+不知道1是A,B,C哪一类的?用x,x+n,x+n+n分别表示A,B,C中有个1】【并查集中用距离表示关系】【压缩路径】

欢迎观看我的博客&#xff0c;如有问题交流&#xff0c;欢迎评论区留言&#xff0c;一定尽快回复&#xff01;&#xff08;大家可以去看我的专栏&#xff0c;是所有文章的目录&#xff09; 文章字体风格&#xff1a; 红色文字表示&#xff1a;重难点 蓝色文字表示&#xff1a;思…

jenkins项目构建类型 -----Pipeline流水线项目构建

壹&#xff0c;概念 pipeline 是一套运行在jenkins上得工作流框架&#xff0c;将原本运行于单个或者多个节点得任务连接起来&#xff0c;用来实现单个任务难以完成得复杂流程编排和可视化得工作。 贰 优点 代码持久可停止多功能可扩展 叁 如何创建Jenkins Pipeline pipeli…