详细解读版本控制工具Git+常见命令实操演示

news2024/11/15 18:22:05

1.版本控制的重要性

版本控制允许开发者查看文件和项目的整个历史记录,包括每次更改的详细记录。在团队项目中,版本控制使得多个开发者可以同时工作在同一个项目上,而不会相互干扰。当引入的错误导致项目出现问题时,版本控制可以快速回滚到之前的稳定版本。

2.Git的基本概念

Git 是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。

版本控制应该有什么功能:简单来讲就是“增删改查”四个字。分别对应:生成新的版本、删除对应的版本、查看所有历史版本、选择指定的版本。

3.Git 的优点

速度非常快; 与 Linux 命令全面兼容; 完全分布式; 有能力高效管理超大规模项目【开源项目】; 使用广泛,行业趋势;

Git的分布式特性是其核心优势之一

  • 完整的本地仓库:每个开发者的本地仓库都包含了项目的完整历史记录,这使得操作更加灵活。

  • 离线操作:开发者可以在没有网络连接的情况下进行大部分Git操作。

  • 更少的合并冲突:由于每个开发者都有完整的历史记录,合并操作更加智能,减少了冲突的可能性。

补充:分布式版本控制系统(Distributed Version Control System, DVCS)与集中式版本控制系统(Centralized Version Control System, CVCS)的主要区别在于:

  • 数据存储:DVCS在每个开发者的本地存储完整的项目历史,而CVCS只在一个中央服务器上存储项目历史。

  • 网络依赖:DVCS允许开发者在离线状态下工作,而CVCS需要网络连接才能进行大部分操作。

  • 容错性:DVCS由于在多个位置存储项目数据,具有更高的容错性。

  • 性能:DVCS通常在性能上优于CVCS,尤其是在大型项目和多用户环境中。

4.Git基本工作流程

当不考虑团队协作时,可以先将Git看作是一个本地化的版本控制工具;Git管理分为了三个区域,分别是:

工作区:这是文件系统的普通目录,包含了项目中的文件;开发者在这里修改和添加文件。

暂存区:一个准备下一次提交的文件列表,位于工作目录和仓库之间;开发者可以通过git add命令将更改添加到暂存区。

本地仓库:包含了项目的整个历史记录,包括所有分支和标签;仓库中有一个特殊的.git目录,它存储了所有元数据和对象数据库。

为了让大家更好地理解暂存区这一概念,还是通过超市的购物车来进行类比:在超市购物时,你的购物车(暂存区)用来暂时存放你选择的商品(更改的文件)。当你准备好结账时,你会把购物车中的商品(使用git commit)转移到收银台(仓库),完成购买(提交)。

5.Git常见命令

git init:创建版本仓库

git status:查看工作区的状态

git add:将工作区变更提交到暂存区

git commit:将暂存区的内容打包成一个版本,存储在版本仓库

git log:查看所有的历史版本

git reset --hard 版本索引:跳转(回滚)到指定的版本

具体操作演示:

新建GitTest文件夹后,再新建A.txt空文件并打开Git Bash;

输入git init之后会在文件夹内会生成.git文件夹,且其为“隐藏的项目”;

此时输入git status(查看工作区的状态)命令后,A.txt文件标红(此时还未添加到暂存区,只在工作区):

打开A.txt文件输入AAAAAA并保存,输入git add *或者git add A.txt命令将其添加到暂存区,然后再查询工作区的状态(此时文件的当前版本已经添加到了暂存区,由于暂存区的版本与工作区的版本一致,故显示:No commits yet);

输入git commit命令将文件从暂存区提交到版本仓库:

此时查看工作区的状态为:

在A.txt文件中添加BBBBBBB后并保存文件:

此时再查看工作区A.txt文件的状态时标红,原因是修改后文件内容与当前版本不一致;

然后将其添加至暂存区,再提交到版本仓库,输入git log可查看版本库操作历史:

使用git reset --hard(索引值)可以回滚到指定版本,例如:

此时打开A.txt文件里面内容为:AAAAA

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

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

相关文章

中吉自动售货机netty对接出货慢问题解决

情景说明: 采购中吉自动售货机,自研对接java代码对接,使用netty方式。(注:有需要对接java对接中吉设备代码的可以关注我们的公众号,联系我们。 对接中吉自动售货机,下发 出货指令,要…

代码随想录算法训练营第四十天| 深搜与广搜理论基础以及模板代码

今天是算法学习第四十天,主要的学习内容是深度优先搜索和广度优先搜索,以及对于模板题的讲解。 深度优先搜索(DFS) 深搜其实原理就是先往一个方向搜索,直到遇到终止条件再回头。所以深度优先搜索的关键就是递归和回溯。 对于深…

超声波清洗机哪个品牌好用?实用性强的超声波眼镜清洗机推荐

眼镜一类的物品都很难清理,特别容易刮花,此外还有小件的首饰,也很难通过常规的清洁方式去除污渍,这时候就要用到超声波清洗机,这两年这种小工具很流行,而超声波清洗机便是其中的一种热门清洁神器&#xff0…

Kafka命令详解:从零开始,掌握Kafka集群管理、主题操作与监控的全方位技能,理解每一条命令背后的逻辑与最佳实践

本文主要是关于Kafka的命令详解,每个命令都进行了非常详细的注释,帮助大家能更好的理解这些命令背后的含义,从底层去理解,如果大家喜欢,请多多点赞关注,欢迎评论! 为大家推荐几篇比较好的Kafka文…

【selenium点选下拉框】解决无法选中对应选项的问题

需求 使用selenium点击下拉框,选中【是】选项。 代码 方法1 # 点击下拉框 driver.find_element(xpath,//*[id"basicProcessDetail"]/div[2]/div[2]/div[1]/div/div[2]/div/div/div/div[1]/div[2]/form/div[11]/div[1]/div/div/div[1]/div[1]/div/i).…

扫描件转word如何操作?分享3个转换技巧,简单高效

在日常工作中,总会遇到扫描件格式的PDF文档,为了方便整理,修改和使用,我们经常需要将扫描件转成可编辑的Word文档,那有哪些方法可以将扫描件转换成Word呢?本期小编就给大家分享3个转换技巧,简单…

mysql索引的基本原理

1.索引的基本原理 是为了提高数据检索效率,通过排列好的数据结构(通常是二叉树或B-Tree)来加快查找过程。1.1 优势 是帮助mysql获取数据的一种高效数据结构,并且是有序的;提高数据的检索效率,降低数据库的…

用IP地址申请SSL证书可行吗?

在当今社会,互联网的安全非常重要,SSL(Secure Sockets Layer)证书作为保障网站安全的重要工具,能够加密网站与用户之间的数据传输,保护用户隐私,提升网站信任度等。然而,传统的SSL证…

【计算机组成原理】四、指令系统:3.汇编语言

5.汇编语言 文章目录 5.汇编语言5.1考试要求(408)x86汇编语言5.2地址码x86架构CPU,有哪些寄存器?总结 5.3操作码5.3.1算术运算5.3.2逻辑运算5.3.3其他 5.4循环分支5.4.1 jmp直接跳转指令5.4.2 jxxx条件跳转指令分支C→汇编循环C→…

Openstack 与 Ceph集群搭建(下): Openstack部署

文章目录 文章参考部署节点准备1. 修改Host文件与hostname名称2. 安装NTP软件3. 网卡配置信息4. 开启Docker共享挂载5. 安装python虚拟环境6. 安装kolla-ansible7. 加载Ansible galaxy requirements Openstack 安装前预配置1. 配置密码2. 配置multinode文件3. 修改全局配置文件…

2.Easy-Paas部署

目录 1.部署方式 2.docker-compose部署 1.1.准备docker环境 1.2.部署中间件 3.k8s部署 1.部署方式 docker-compose部署(单节点)k8s部署自研ops 2.docker-compose部署 1.1.准备docker环境 参考:二进制安装docker-CSDN博客 1.2.部署中…

安科瑞储能双向计量表DTSD1352-CT/CF 双向电量复费率统计

安科瑞徐赟杰 Hey科技迷们,你们是否对能源管理的新纪元充满好奇? 今天咱们来聊聊这款颠覆性的黑科技——安科瑞储能双向计量表DTSD1352! 想象一下,一个能够掌控能量流动,无论是输入还是输出,都了如指掌的…

Thread类的基本用法(详解版)

什么是线程? 线程是操作系统能够进行调度的最小单位,通常被视为轻量级的进程。线程在同一进程中共享进程的资源(如内存,打开的文件,网络等),但每一个线程都有自己的执行栈、程序计数器和局部变…

项目管理中什么是项目质量管理?

所有项目经理都易于犯下的通病便是产生无谓的乐观,误以为质量会自然而然地融入项目之中。然而,在实际操作中,我们必须明确界定、监控并管理项目管理质量。 项目质量管理的核心在于确保项目质量。这被称为项目的第四个约束,经理们必…

澄志创投马良骏:营销技术行业下一个关键词是合并与整合 | 中国广告营销行业资本报告深访①

日前,澄志创投发布了《中国广告营销行业资本报告2022》,投中信息提供独家数据支持,Marteker联合撰写。报告围绕广告营销行业的资本运作等话题,采访了行业资深人士。 马良骏Joshua(澄志创投创始人) 问&#…

Module not found: Can‘t resolve ‘tls‘/Module not found: Can‘t resolve ‘net‘

最近使用nextjs开发了一套系统,包含了前后端,但是前后端的界限其实没有那么清晰,很多地方都引入了公共的内容,甚至互相引入了其模块的内容 然后周五时在前端引入了一个方法(该方法在前端的模块里面定义的,之…

【Linux】基本命令(第二篇)

目录 1.命令提示符 2.命令的基本格式 1) 选项的作用 2) 参数的作用 2.cd命令:切换目录 3.pwd命令:显示当前路径 4.ls命令:查看目录下文件 5.mkdir命令:创建目录(文件夹) 6.rmdir命令:删…

《黑神话:悟空》横空出世:全新国产3A里程碑之作

“直面天命”、“棒打虎先锋”、“猿神,启动”......在过去的一周里,从朋友圈到微博热搜,从咖啡联名到陕西文旅,几乎已经没有人,可以对《黑神话:悟空》这一国产3A里程碑之作视而不见。8月20日上午10时&…

eclipse汉化教程

1:选择HELP->install New software 2:点击Add 3:name随便填写,location:https://download.eclipse.org/technology/babel/update-site/latest/ 4:等待下载完成后点next 5:选择中文,再点击next 6. 等待…

【实战】Spring Boot 嵌套事务REQUIRES_NEW与NESTED在项目中的运用

文章目录 引言1. 什么是Nested Transactions?2. Spring Boot中的事务管理2.1 基本用法2.2 Nested Transactions的需求场景 3. 实现Nested Transactions3.1 使用Propagation.REQUIRED)/Propagation.NESTED)3.2 嵌套事务REQUIRES_NEW与NESTED3.3 注意事项 4. 测试Nested Transac…