git 使用详解(1)--历史

版本控制系统(VCS)::有了它你就可以将某个文件回溯到之前的状态,甚至将整个项目都回退到过去某个时间点的状态。你可以比较文件的变化细节,查出最后是谁修改了哪个地方,从而导致出现怪异问题,又是谁在何时报告了某个功能缺陷等等。使用版本控制系统通常还意味着,就算你乱来一气把整个项目中的文件改的改删的删,你也照样可以轻松恢复到原先的样子。但额外增加的工作量却微乎其微。

集中化的版本控制系统

如何让在不同系统上的开发者协同工作?于是,集中化的版本控制系统( Centralized Version Control Systems,简称 CVCS )应运而生。这类系统,诸如 CVS,Subversion 以及 Perforce 等,都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务器,取出最新的文件或者提交更新。多年以来,这已成为版本控制系统的标准做法(见图 1-2)


图 1-2. 集中化的版本控制系统

现在,每个人都可以在一定程度上看到项目中的其他人正在做些什么。而管理员也可以轻松掌控每个开发者的权限,并且管理一个 CVCS 要远比在各个客户端上维护本地数据库来得轻松容易。

事分两面,有好有坏。这么做最显而易见的缺点是中央服务器的单点故障。如果宕机一小时,那么在这一小时内,谁都无法提交更新,也就无法协同工作。要是中央服务器的磁盘发生故障,碰巧没做备份,或者备份不够及时,就还是会有丢失数据的风险。最坏的情况是彻底丢失整个项目的所有历史更改记录,而被客户端提取出来的某些快照数据除外,但这样的话依然是个问题,你不能保证所有的数据都已经有人事先完整提取出来过。本地版本控制系统也存在类似问题,只要整个项目的历史记录被保存在单一位置,就有丢失所有历史更新记录的风险。

分布式版本控制系统

于是分布式版本控制系统( Distributed Version Control System,简称 DVCS )面世了。在这类系统中,像 Git 等,客户端并不只提取最新版本的文件快照,而是把原始的代码仓库 完整地 镜像下来。这么一来,任何一处协同工作用的服务器发生故障,事后都可以用任何一个镜像出来的本地仓库恢复。因为每一次的提取操作,实际上都是一次对代码仓库的完整备份(见图 1-3)。

图 1-3. 分布式版本控制系统

更进一步,许多这类系统都可以指定和若干不同的远端代码仓库进行交互。籍此,你就可以在同一个项目中,分别和不同工作小组的人相互协作。你可以根据需要设定不同的协作流程,比如层次模型式的工作流,而这在以前的集中式系统中是无法实现的。

Git 基础

Git 究竟是怎样的一个系统呢?若是理解了 Git 的思想和基本工作原理,用起来就会知其所以然,游刃有余。在开始学习 Git 的时候,请不要尝试把各种概念和其他版本控制系统(诸如 Subversion 和 Perforce 等)相比拟,否则容易混淆每个操作的实际意义。

直接记录快照,而非差异比较

Git 和其他版本控制系统的主要差别在于,Git 只关心文件数据的整体是否发生变化,而大多数其他系统则只关心 文件内容 的 具体差异。这类系统(CVS,Subversion,Perforce,Bazaar 等等)每次记录有哪些文件作了更新,以及都更新了哪些行的什么内容,请看图 1-4。

图 1-4. 其他系统在每个版本中记录着各个文件的具体差异

Git 并 不保存 这些前后变化的差异数据。实际上,Git 更像是把变化的文件作快照后,记录在一个微型的文件系统中。每次提交更新时,它会纵览一遍所有文件的指纹信息并对文件作一快照,然后保存一个指向这次快照的索引。为提高性能,若文件没有变化,Git 不会再次保存,而只对上次保存的快照作一链接。

图 1-5. Git 保存每次更新时的文件快照

这是 Git 同其他系统的重要区别。Git 更像是个小型的文件系统,但它同时还提供了许多以此为基础的超强工具,而不只是一个简单的 VCS。

在 Git 中的绝大多数操作都只需要访问本地文件和资源,不用连网。但如果用 CVCS 的话,差不多所有操作都需要连接网络。因为 Git 在本地磁盘上就保存着所有当前项目的历史更新,所以处理起来速度飞快。

时刻保持数据完整性

Git 使用 SHA-1 算法计算数据的校验和,通过对文件的内容或目录的结构计算出一个 SHA-1 哈希值,作为指纹字符串。该字串由 40 个十六进制字符(0-9 及 a-f)组成,看起来就像是:
24b9da6552252987aa493b52f8696cd6d3b00373

Git 的工作完全依赖于这类指纹字串,所以你会经常看到这样的哈希值。实际上,所有保存在 Git 数据库中的东西都是用此哈希值来作索引的,而不是靠文件名。

多数操作仅添加数据

常用的 Git 操作大多仅仅是把数据添加到数据库。因为任何一种不可逆的操作,比如删除数据,都会使回退或重现历史版本变得困难重重。

但在 Git 里,一旦提交快照之后就完全不用担心丢失数据,特别是养成定期推送到其他仓库的习惯的话。

文件的三种状态

对于任何一个文件,在 Git 内都只有三种状态:已提交(committed),已修改(modified)和 已暂存(staged)。已提交表示该文件已经被安全地保存在本地数据库中了;已修改表示修改了某个文件,但还没有提交保存;已暂存表示把已修改的文件放在下次提交时要保存的清单中。

由此我们看到 Git 管理项目时,文件流转的三个工作区域:Git 的工作目录,暂存区域,以及本地仓库。

图 1-6. 工作目录,暂存区域,以及本地仓库

每个项目都有一个 Git 目录(译注:如果 git clone 出来的话,就是其中 .git 的目录;如果git clone --bare的话,新建的目录本身就是 Git 目录。),它是 Git 用来保存元数据和对象数据库的地方。该目录非常重要,每次克隆镜像仓库的时候,实际拷贝的就是这个目录里面的数据

从项目中取出某个版本的所有文件和目录,用以开始后续工作的叫做工作目录。这些文件实际上都是从 Git 目录中的压缩对象数据库中提取出来的,接下来就可以在工作目录中对这些文件进行编辑。

所谓的暂存区域只不过是个简单的文件,一般都放在 Git 目录中。有时候人们会把这个文件叫做索引文件,不过标准说法还是叫暂存区域。

基本的 Git 工作流程如下:

1. 在工作目录中修改某些文件。

2. 对修改后的文件进行快照,然后保存到暂存区域。 

3. 提交更新,将保存在 暂存区域 的文件快照永久转储到  Git 目录 中

所以,我们可以从文件所处的位置来判断状态:如果是 Git 目录中保存着的特定版本文件,就属于已提交状态;如果作了修改并已放入暂存区域,就属于已暂存状态;如果自上次取出后,作了修改但还没有放到暂存区域,就是已修改状态。


### 回答1: Git cherry-pick是一种从其他分支复制特定提交到当前分支的命令,它可以提取某个提交到当前分支,而不用将整个分支合并。使用cherry-pick,可以从一个分支中选择某个提交,并将其添加到其他分支。 ### 回答2: git cherry-pick是一种常用的Git命令,用于选择性地将某个分支的单个或多个提交应用到当前分支上。 使用git cherry-pick的基本语法是:git cherry-pick <commit-hash> 其中<commit-hash>是待应用的提交的哈希值。可以通过git log命令查看哈希值。 具体使用git cherry-pick的详解如下: 1. 切换到当前分支:使用git checkout <branch-name>切换到当前分支。 2. 执行git cherry-pick命令:使用git cherry-pick <commit-hash>将待应用的提交应用到当前分支上。可以一次选择多个提交,只需提供相应的多个commit-hash。 3. 解决冲突:如果待应用的提交与当前分支有冲突,则需要手动解决冲突。可以使用git status命令查看冲突的文件,并对其进行手动修改。 4. 继续应用剩余的提交:在解决冲突后,使用git cherry-pick --continue命令继续应用剩余的提交。 5. 取消应用:如果在应用过程中遇到问题,可以使用git cherry-pick --abort命令取消应用,恢复到操作前的状态。 需要注意的是,git cherry-pick只是将指定的提交应用到当前分支上,并不会将整个分支合并。因此,在使用过程中需要谨慎选择待应用的提交,以免引入不必要的问题。 另外,如果在使用git cherry-pick命令时遇到困难,可以通过查阅官方文档或在社区寻求帮助。 ### 回答3: git cherry-pick是Git版本控制系统中的一个命令,用于选择性地将指定提交(commit)应用到当前分支上。 使用git cherry-pick的第一步是获取需要的提交的提交号(commit hash)。可以通过使用git log命令来查看提交历史并复制提交号。然后,在需要应用提交的分支上使用git cherry-pick命令,后面跟着要应用的提交号。 执行git cherry-pick命令后,Git会尝试将指定提交的更改应用到当前分支上,创建一个新的提交。如果应用成功,则当前分支会包含指定提交的更改。 git cherry-pick还可以选择提交范围。可以通过提供两个提交号来选择一系列连续的提交,或通过使用^符号来选择指定提交之前的所有提交。例如,git cherry-pick commit1^..commit2将选择commit1之后一直到commit2之前的所有提交。 需要注意的是,使用git cherry-pick应用提交时,可能会发生冲突。这是因为正在应用的提交与当前分支的更改发生了冲突。Git会在发生冲突时暂停cherry-pick操作,等待用户手动解决冲突后再继续。 如果在执行git cherry-pick之前已经存在一些未提交的更改,那么Git也会在应用提交时暂停,等待用户先提交或保存这些更改。 总结来说,git cherry-pick是一个强大的命令,它允许我们有选择地将指定提交的更改应用到当前分支上,而不需要将整个分支合并过来。这使得我们能够更灵活地管理提交的引入,只应用我们需要的更改,并避免引入不必要的冲突或代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值