git 版本控制与合并

news2025/1/12 10:48:28

 一   git概述:


- Git是一种分布式版本控制系统,用于跟踪和管理软件开发项目中的代码变更。
- 它允许多人协同工作,记录代码历史变更,并轻松管理多个项目版本。

**Git的主要特点**包括:

1. **分布式系统**:每个开发者都拥有完整的存储库副本,可以在本地进行提交、分支和合并操作,而无需依赖中央服务器。这使得团队成员可以离线工作,减少了网络依赖性,并提高了效率和灵活性。

2. **快速和高效**:Git以本地操作为主,因此执行速度非常快,即使在大规模项目上也能保持高效。

3. **强大的分支和合并**:Git的分支功能非常强大,允许开发者轻松创建、合并和切换分支,便于并行开发和测试新功能。

4. **数据完整性**:Git中的数据以不可更改的哈希值保存,确保每个版本都能完整地被追踪和验证。

5. **灵活的工作流程**:Git支持多种工作流程,可以适应不同团队和项目的需求。

6. **大型项目支持**:Git在处理大规模项目时表现出色,能够高效地管理海量代码。

 二 . Git安装,配置,初始化:

1. **Git安装**:
   - 在Windows上:下载适用于Windows的Git安装程序并运行安装向导。您可以从Git官方网站(https://git-scm.com/downloads)获取安装程序。
   - 在macOS上:如果您使用Homebrew,可以在终端中运行`brew install git`来安装Git。否则,您可以从Git官方网站下载macOS的安装程序并进行安装。
   - 在Linux上:使用系统包管理器来安装Git。例如,在Ubuntu上,可以运行`sudo apt-get install git`。

2. **Git配置**:
   - 配置用户名:在安装Git后,首先设置全局的用户名和电子邮件地址。这将用于标识您的提交记录。在终端中运行以下命令:
     ```
     git config --global user.name "Your Name"  (这里账号邮箱不用填写真实的) 
     git config --global user.email "your.email@example.com"  
     ```
   - 您还可以配置其他的Git选项,例如文本编辑器等。

3. **Git初始化**:
   - 在本地项目目录中,使用 `git init` 命令将该目录初始化为Git仓库。这将创建一个.git文件夹,用于存储Git的配置和版本历史信息。
   - 在终端中进入项目目录,运行:
     ```
     cd /path/to/your/project
     git init
     ```

三 . Git文件状态和提交版本:
 

在Git中,文件有三种主要状态,用于跟踪文件在版本控制中的变化情况。这三种文件状态是:

流程: 

新建到仓库的所有文件  未跟踪状态      
git add  变为暂存状态 git commit 提交后 形成新版本 文件变为未修改状态   在未修改状态可以通过 git rm 变为未跟踪状态  对未修改文件进行修改就变成已修改状态   对已修改文件使用git add 变暂

1. **未跟踪(Untracked)**:
   - 当您在Git仓库中新建一个文件或添加一个未被Git管理的文件时,该文件处于未跟踪状态。
   - 未跟踪的文件不在Git的版本管理之下,Git不会追踪其变化或将其包含在提交中。

2. **已修改(Modified)**:
   - 如果在上一次提交之后,对已经被Git管理的文件进行了修改,这些文件就处于已修改状态。
   - Git通过比较文件的当前状态和最后一次提交时的状态来确定文件是否处于已修改状态。

3. **已暂存(Staged)**:
   - 当您对已修改的文件使用 `git add` 命令后,文件会进入已暂存状态。
   - 已暂存的文件表示它们的最新修改已经被放入暂存区(Staging Area),准备提交成为新的版本。

下面是一些常见的文件状态示例及其对应的含义:

- `Untracked`:新建的文件或还未添加到Git仓库中的文件。
- `Modified`:已被Git管理的文件,在上一次提交之后被修改过,但尚未添加到暂存区。
- `Staged`:已被Git管理的文件,在上一次提交之后被修改过,并已添加到暂存区,准备提交成为新的版本。
- `Unmodified`:已被Git管理的文件,在上一次提交之后未发生过修改,处于稳定状态。

四. Git远程仓库:

Git远程仓库是一个位于网络上的代码仓库,用于存储代码和版本历史。使用远程仓库,团队成员可以在不同地点协同开发,并方便地分享代码。在Git中,可以将远程仓库添加为项目的一个远程链接,并与之交互。

1. **克隆远程仓库:** 使用 `git clone` 命令可以将远程仓库完整地复制到本地,创建一个本地副本。克隆后,您将拥有远程仓库的所有历史和分支。

   ```
   git clone <remote_repository_url>
   ```

2. **添加远程仓库:** 使用 `git remote add` 命令将远程仓库添加到本地仓库的远程仓库列表中。通常,远程仓库会被命名为 "origin"。

   ```
   git remote add origin <remote_repository_url>
   ```

3. **推送到远程仓库:** 使用 `git push` 命令将本地的提交推送到远程仓库。推送时,您需要指定要推送的分支。

   ```
   git push <remote_name> <branch_name>
   ```

4. **拉取远程仓库:** 使用 `git pull` 命令可以从远程仓库拉取最新的代码和提交,将本地代码与远程仓库同步。

   ```
   git pull <remote_name> <branch_name>
   ```

5. **查看远程仓库:** 使用 `git remote` 命令可以查看当前已添加的远程仓库列表。

   ```
   git remote -v
   ```

6. **删除远程仓库:** 使用 `git remote remove` 命令可以删除不再需要的远程仓库。

   ```
   git remote remove <remote_name>
   ```

 五 . Git分支:

它允许团队成员在不同的分支上独立开发不同的功能,然后将这些功能集成到主线代码中。使用分支可以避免直接在主线代码上进行修改,保持主线代码的稳定性,并提高开发效率。


- 创建分支:使用 `git branch` 创建新的分支。
- 切换分支:使用 `git checkout` 或 `git switch` 切换到其他分支。
- 分支合并:使用 `git merge` 将分支合并到主分支

六.  Git推送,拉取,跟踪远程分支:

在Git中,推送(Push)、拉取(Pull)和跟踪(Track)远程分支是与远程仓库交互的常见操作。这些操作允许您在本地仓库和远程仓库之间同步代码,以便与其他团队成员共享和合作开发。

1. **推送远程分支:**
   - 使用 `git push` 命令将本地分支的提交推送到远程仓库中。如果远程分支不存在,将会创建一个同名的远程分支。

   ```
   git push <remote_name> <local_branch_name>
   ```

   例如,要将本地的主分支(master)推送到远程仓库的主分支,可以执行:

   ```
   git push origin master
   ```

2. **拉取远程分支:**
   - 使用 `git pull` 命令从远程仓库拉取最新的代码和提交,将本地分支与远程分支合并。

   ```
   git pull <remote_name> <remote_branch_name>
   ```

   例如,要从远程仓库的主分支(master)拉取最新代码并合并到本地的主分支,可以执行:

   ```
   git pull origin master
   ```

3. **跟踪远程分支:**
   - 使用 `git checkout -b` 命令可以在本地创建并切换到一个新的分支,并与指定的远程分支建立跟踪关系。

   ```
   git checkout -b <local_branch_name> <remote_name>/<remote_branch_name>
   ```

   例如,要创建一个新分支并跟踪远程的开发分支(dev),可以执行:

   ```
   git checkout -b feature dev
   ```

跟踪远程分支的好处是,当您使用 `git pull` 命令时,Git会自动将远程分支的代码更新到您所跟踪的本地分支上。这样,您就可以轻松地与团队成员共享代码和提交,并保持与远程仓库同步。在多人协作的开发环境中,推送、拉取和跟踪远程分支是非常常见的操作。

 七 . Git存储功能:
 

在Git中,`git stash` 是一个有用的命令,用于将当前工作目录中的未提交的修改暂时保存起来,以便可以切换到其他分支或处理其他任务。`git stash` 可以将您的工作目录恢复到上一次提交后的状态,同时保留未提交的修改。

使用 `git stash` 的基本用法如下:

1. **保存工作目录的修改:** 在进行一些修改但不想提交它们的情况下,使用 `git stash` 命令将修改暂存。

   ```
   git stash
   ```

   这将暂存当前工作目录中的所有未提交的修改。

2. **查看保存的存储列表:** 使用 `git stash list` 命令可以查看当前存储的列表,显示所有已保存的存储。

   ```
   git stash list
   ```

3. **应用存储的修改:** 使用 `git stash apply` 命令可以将最新的存储恢复到当前工作目录中。

   ```
   git stash apply
   ```

   如果有多个存储,您可以使用 `git stash apply stash@{n}` 来应用指定的存储。

4. **删除存储:** 使用 `git stash drop` 命令可以删除最新的存储。

   ```
   git stash drop
   ```

   如果要删除指定的存储,可以使用 `git stash drop stash@{n}`。

5. **应用并删除存储:** 使用 `git stash pop` 命令可以恢复并删除最新的存储。

   ```
   git stash pop
   ```

   如果要恢复并删除指定的存储,可以使用 `git stash pop stash@{n}`。

使用 `git stash` 命令非常方便,特别是在您需要切换到其他分支或处理其他任务时,但又不想提交当前的修改。它允许您暂时保存您的工作进度,并在需要时轻松恢复。请注意,`git stash` 仅保存已跟踪的文件,对于新建的、未跟踪的文件和空的目录不会保存。

八   Git重置和变基:


- 重置:

在Git中,重置(Reset)是一种用于更改当前分支的指针位置和文件状态的操作。它允许您回退到不同的提交状态或撤销已提交的修改。Git提供了三种重置模式:软重置(Soft Reset)、混合重置(Mixed Reset)和硬重置(Hard Reset)。每种模式对分支指针和工作目录的影响略有不同。

1. **软重置(Soft Reset):**
   软重置保留当前的修改,并将分支指针移动到指定的提交位置。这意味着Git将当前分支指向新的提交,但不会撤销工作目录或暂存区的内容。软重置通常用于撤销一次提交,并将提交的修改重新提交。

   ```
   git reset --soft <commit_hash>
   ```

2. **混合重置(Mixed Reset):**
   混合重置是重置的默认模式。它不仅移动分支指针,还会取消暂存区的内容。这意味着Git将当前分支指向新的提交,并且取消暂存区的所有内容,但工作目录的修改仍然保留。混合重置通常用于撤销一次提交并取消暂存区的文件。

   ```
   git reset --mixed <commit_hash>
   ```

3. **硬重置(Hard Reset):**
   硬重置是最强制性的重置模式。它不仅移动分支指针,还会彻底删除工作目录和暂存区的内容,将它们恢复到指定的提交状态。这意味着Git将当前分支指向新的提交,并且会永久删除所有未提交的修改。慎用硬重置,因为它可能导致数据丢失。

   ```
   git reset --hard <commit_hash>
   ```

请谨慎使用重置操作,特别是在已经推送到远程仓库的分支上。如果您不确定重置的影响,请确保在使用重置之前备份您的工作目录或创建一个新的分支来尝试。重置是一种强制性的历史修改操作,应谨慎使用。


- 变基:

在Git中,变基(Rebase)是一种用于修改提交历史的操作,它允许您将一个分支的修改应用到另一个分支上,从而使项目的提交历史更加整洁和线性。变基通过将一个分支上的提交依次应用到另一个分支的末尾,从而创建一个新的提交历史。

使用变基可以避免分支合并产生的冗余提交,使项目的提交历史更易于理解和维护。然而,变基也需要谨慎使用,特别是在与他人协作的情况下,因为它会修改提交的SHA哈希值,可能会引起冲突或不良影响。

下面是一些关于如何使用Git变基的基本步骤:

1. **切换到目标分支:** 首先,切换到您要将修改应用到的目标分支。

   ```
   git checkout <target_branch>
   ```

2. **执行变基操作:** 使用 `git rebase` 命令来执行变基操作,将源分支的修改应用到目标分支上。

   ```
   git rebase <source_branch>
   ```

   例如,要将`feature`分支的修改变基到`master`分支上,可以执行:

   ```
   git checkout master
   git rebase feature
   ```

3. **解决冲突(如果有):** 在变基过程中,如果源分支的提交与目标分支的提交产生冲突,Git会提示您解决这些冲突。您需要手动解决冲突,然后使用 `git add` 将解决后的文件标记为已解决。

4. **继续变基:** 在解决冲突后,使用 `git rebase --continue` 继续变基操作。

5. **完成变基:** 当所有的冲突都解决并且变基操作完成后,您可以使用 `git rebase --skip` 或 `git rebase --abort` 来继续或中止变基。

总之,变基是一种强大的工具,可以帮助您保持项目的提交历史整洁和易于理解。然而,在使用变基时,请务必小心处理,尤其是在共享分支上,以免影响他人的工作。如果不确定如何使用变基,建议先在自己的分支上进行尝试。

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

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

相关文章

嵌入式开发学习(STC51-14-时钟)

内容 在数码管上显示时间&#xff0c;时分秒&#xff0c;格式为“XX-XX-XX”&#xff1b; DS1302时钟芯片介绍 简介 DS1302是DALLAS公司推出的涓流充电时钟芯片&#xff0c;内含有一个实时时钟/日历和31字节静态RAM&#xff0c;通过简单的串行接口与单片机进行通信&#xf…

系统架构设计高级技能 · 软件架构概念、架构风格、ABSD、架构复用、DSSA(一)【系统架构设计师】

系列文章目录 C技能系列 Linux通信架构系列 C高性能优化编程系列 深入理解软件架构设计系列 高级C并发线程编程 设计模式系列 期待你的关注哦&#xff01;&#xff01;&#xff01; 现在的一切都是为将来的梦想编织翅膀&#xff0c;让梦想在现实中展翅高飞。 Now everythin…

第4集丨Vue 江湖 —— 计算属性

目录 一、基本使用1.1 在computed中定义1.1.1 案例1.1.2 控制台调用getter1.1.3 控制台中的data和computed 1.2 缓存效果1.3 完整写法1.3.1 案例1.3.2 效果图 1.4 简写形式 二、案例的其他实现2.1 methods实现2.2 插值语法实现 三、体会计算属性的好处3.1 复杂任务时3.2 使用计…

IO模型-信号驱动IO

linux内核中存在一个信号SIGIO&#xff0c;这个信号就是用于实现信号驱动IO的。当应用程序中想要以信号驱动IO的模型读写硬件数据时&#xff0c;首先注册一个SIGIO信号的信号处理函数,当硬件数据就绪&#xff0c;硬件会发起一个中断&#xff0c;在硬件的中断处理函数中向当前进…

求解n阶勒让德多项式的值

描述 用递归方法求n阶勒让德多项式的值&#xff0c;递归公式为&#xff1a; 在主函数中输入一个整数n和一个实数x&#xff0c;调用函数 legendre(n,x)&#xff0c;并输出其返回值。 输入 第一行输入一个整数n&#xff0c;表示阶数&#xff1b;第二行输入一个实数x。 输出 …

增强型Web安全网关在银行的应用

销售&#xff0c;绝不是降低身份去取悦客户&#xff0c;而是像朋友一样给予合理的建议。你刚好需要&#xff0c;我刚好专业&#xff01;仅此而已&#xff01; 乔.吉拉德 健康的安全体系&#xff0c;还可以更完善 浙江某商业银行股份有限公司是一家成立多年的商业银行&#xf…

分布式异步任务处理组件(七)

分布式异步任务处理组件底层网络通信模型的设计--如图&#xff1a; 使用Java原生NIO来实现TCP通信模型普通节点维护一个网络IO线程&#xff0c;负责和主节点的网络数据通信连接--这里的网络数据是指组件通信协议之下的直接面对字节流的数据读写&#xff0c;上层会有另一个线程负…

装饰器模式(C++)

定义 动态(组合)地给一个对象增加一些额外的职责。就增加功能而言&#xff0c;Decorator模式比生成子类(继承)更为灵活(消除重复代码&减少子类个数)。 一《设计模式》 GoF 装饰器模式&#xff08;Decorator Pattern&#xff09;允许向一个现有的对象添加新的功能&#xf…

视频安防监控EasyCVR平台海康大华设备国标GB28181告警布防的报文说明

TSINGSEE青犀视频监控综合管理平台EasyCVR基于云边端协同&#xff0c;可支持海量视频的轻量化接入与汇聚管理。平台既具备传统安防视频监控的能力&#xff0c;比如&#xff1a;视频监控直播、云端录像、云存储、录像检索与回看、告警上报、平台级联、云台控制、语音对讲等&…

第一课-前提-Stable Diffusion 教程

学习 SD 的前提是电脑配置! SD 参考配置: 建议选择台式机 i5 CPU, 内存16GB,N卡 RTX3060, 8G显存以上的配置(最低配) 在此基础上的配置越高越好。 比如,cpu i7 更好,显卡能有 RTX4090 更好,32显存要能有最好,嘿嘿嘿。 如何查看自己的显卡配置? Win+R 输入 “dxdiag…

vue2-v-if和v-for的优先级是什么?

1、v-if和v-for的区别 作用&#xff1a; v-if指令用于条件性地渲染一块内容&#xff0c;这块内容只会在指令的表达式返回true值的时候被渲染。 v-for指令基于一个数组来渲染一个列表&#xff0c;v-for指令需要使用item in items 形式的特殊语法&#xff0c;其中&#xff0c;it…

自学(黑客)技术,从入门到精通!

1.网络安全是什么 网络安全可以基于攻击和防御视角来分类&#xff0c;我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术&#xff0c;而“蓝队”、“安全运营”、“安全运维”则研究防御技术。 2.网络安全市场 一、是市场需求量高&#xff1b; 二、则是发展相对成熟入…

Vue3 模板语法简单应用

去官网学习-》 模板语法 | Vue.js 运行示例&#xff1a; 代码&#xff1a;HelloWorld.vue <template><div class"hello"><h1>Vue 模板语法</h1><h2>{{ msg }}</h2><h2>{{ textHtml }}</h2><h2 v-html"text…

【单运放RC振荡器1负反馈方波2正反馈正弦波方波】2021-12-9

缘由multisim运放芯片给一个连上电源另一个引脚打叉不能仿真-测试-CSDN问答 正反馈电阻影响转化阀值,负反馈电阻影响频率 固定负反馈为2时无法起震荡,电位器调节到2%可振荡且波形失真,电位器调节到0%且固定负反馈为2时才能正弦波输出

Spring Boot 集成Seata

Seata的集成方式有&#xff1a; 1. Seata-All 2. Seata-Spring-Boot-Starter 3. Spring-Cloud-Starter-Seata 本案例使用Seata-Spring-Boot-Starter演示&#xff1a; 第一步&#xff1a;下载Seata 第二步&#xff1a;为了更好看到效果&#xff0c;我们将Seata的数据存储改…

MyBatis 查询数据库之二(增、删、改、查操作)

目录 1. 配置打印 MyBatis 执行的SQL 2. 查询操作 2.1 通过用户 ID 查询用户信息、查询所有用户信息 (1) Mapper 接口 (2)UserMapper.xml 查询所有用户的具体实现 SQL (3)进行单元测试 3. 增加操作 3.1 在 mapper&#xff08;interface&#xff09;里面添加增加方法的声…

git仓库与本地暂存区的同步问题

向下同步 对于远程仓库的项目&#xff0c;初始化一个配置文件&#xff0c;配置远程仓库及相关信息&#xff0c;赋值远程仓库的地址&#xff0c;使用git pull命令即可拉取仓库代码。 git pull [remote_addr] 该部分完成向下同步 向上同步 向上同步时会遇到很多的问题&#xf…

viewerjs 如何新增下载图片功能(npm包补丁)

文章目录 先实现正常的效果实现下载图片改变viewerjs的build函数源码改变之后&#xff0c;执行npm i 之后node_modules源码又变回了原样 1、viwerjs所有功能都很完善&#xff0c;但唯独缺少了图片的下载 2、需求&#xff1a;在用viwerjs旋转图片后&#xff0c;可以直接下载旋转…

计算机视觉与图形学-神经渲染专题-Seal-3D(基于NeRF的像素级交互式编辑)

摘要 随着隐式神经表示或神经辐射场 (NeRF) 的流行&#xff0c;迫切需要与隐式 3D 模型交互的编辑方法&#xff0c;以完成后处理重建场景和 3D 内容创建等任务。虽然之前的作品从不同角度探索了 NeRF 编辑&#xff0c;但它们在编辑灵活性、质量和速度方面受到限制&#xff0c;无…