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