欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

适合新手学习的git教程分享

程序员文章站 2023-11-30 18:20:22
适合新手学习的git教程分享...

git 起源
同生活中的许多伟大事件一样,git 诞生于一个极富纷争大举创新的年代。linux 内核开源项目有着为数众广的参与者。绝大多数的 linux 内核维护工作都花在了提交补丁和保存归档的繁琐事务上(1991-2002年间)。到 2002 年,整个项目组开始启用分布式版本控制系统 bitkeeper 来管理和维护代码。到了 2005 年,开发 bitkeeper 的商业公司同 linux 内核开源社区的合作关系结束,他们收回了免费使用 bitkeeper 的权力。这就迫使 linux 开源社区(特别是 linux 的缔造者 linus torvalds )不得不吸取教训,只有开发一套属于自己的版本控制系统才不至于重蹈覆辙。他们对新的系统制订了若干目标:
git 和其他版本控制系统的主要差别在于,git 只关心文件数据的整体是否发生变化,而大多数其他系统则只关心文件内容的具体差异。这类系统(cvs,subversion,perforce,bazaar 等等)每次记录有哪些文件作了更新,以及都更新了哪些行的什么内容.
git 并不保存这些前后变化的差异数据。实际上,git 更像是把变化的文件作快照后,记录在一个微型的文件系统中。每次提交更新时,它会纵览一遍所有文件的指纹信息并对文件作一快照,然后保存一个指向这次快照的索引。为提高性能,若文件没有变化,git 不会再次保存,而只对上次保存的快照作一链接.这是 git 同其他系统的重要区别。它完全颠覆了传统版本控制的套路,并对各个环节的实现方式作了新的设计。git 更像是个小型的文件系统

1、创建新仓库


代码如下:

初始化新仓库,在当前目录下由一个.git的目录,所有git需要的数据和资源都放在这个目录中,在当面目录下添加文件后,需要通过gitadd添加到文件追踪管理(添加到暂存区,数据存放在.git/index目录索引,数据内部保存在.git/objects中),gitcommit-m"提交说明备注"提交的信息会提交到数据仓库,数据提交到正式仓库,具体保存在.git/objects中,如以上提交会包含一个commit,tree,blob对象。

2、从现有仓库克隆

代码如下:
如从github上克隆一份linux的源码,不仅是克隆最新版本的源码,还克隆了所有数据仓库的历史版本,每个文件的每一个版本,这个时候及时服务器github发生故障,可以用本地数据仓库重建服务器上的仓库。可以回复到从服务器克隆或最后更一次从服务器拉去的状态。在.git目录中,已经保存了所有版本记录,本地文件夹即工作目录的所有文件删除了,然后从中取出最新版本的文件拷贝。

3、检查文件更新状态
要求确定当前工作区和暂存区文件的状态,可以通过gitstatus命令。在工作区和暂存区的目录状态可以查看。
gitstatus
onbranchmasternothingtocommit,workingdirectoryclean
当前在默认master分支,当前工作目录和暂存区没有任何跟踪的文件,也没有任何文件提交后更改,也没有新增加,未被跟踪的文件。
notepadtest.txt
notepadt.txt
修改test.txt文件,新添加一个t.txt文件,查看当前文件状态。


代码如下:

新增加的文件t.txt在未跟踪文件范围untrackedfiles范围,需要通过gitadd把改文件添加的暂存区,归入的版本跟踪管理。

4、添加文件到暂存区

代码如下:

gitadd.把当前所有目录文件所有新文件和修改文件添加到暂存区,如果test.txt文件提示是changesnotstagedforcommit,说明此跟踪文件已经发生修改,但是还未添加到暂存区,把修改的文件通过gitadd命令添加到暂存区后。提示changestobecommitted.文件已经暂存,随时可以提交到仓库。h.txt新添加文件从未跟踪状态untrackedfiles,通过gitadd命令添加到暂存区,已加入跟踪文件的范围。

5、版本提交

代码如下:

通过gitcommit-m"xxx"将当前暂存区的内容提交到仓库,本次commit提交文件是在默认master分支,提交commit对象存放在.git/objects的d4/1498a...的文件中,该文件指向一个树tree对象。

6、查看当前提交日志记录

代码如下:

gitlog命令查看当前版本


7、文件差异比较

工作区和暂存区文件比较用gitdiff命令,暂存区和最近一天提交版本之间的差异,可以用gitdiff--cached/staged.如下:
目前在test.txt文件只有1111111文件内容,我在文件test.txt中添加22222222等内容,比较当前暂存区和工作文件差异


代码如下:

把工作区修改的内容更新到暂存区后,可以看出此时暂存区和工作区文件完全相同。状态是是已暂存,带提交状态。与此同时,我们可以比较暂存区和数据残酷之间的差异和比较。


代码如下:

我们可以很清楚的看到当前暂存区和数据仓库版本比较。暂存区test.txt内容比最近一次提交内容多22222222222222一行数据。提交数据到数据仓库。我们现在可以把工作区目录和数据仓库比较,看看test.txt直接的文件内容差异。


代码如下:

可以很立即看出工作区文件内容比较仓库有新修改的内容。此时我们提交更新所有文件都没有差异了。看看文件差异。


代码如下:

8、文件删除和移动

所有的工作区rmxxx删除后,可以直接从数据仓库获取最近一次提交版本的内容gitrmxxx。直接从数据仓库删除此文件内容。


代码如下:

可以通过文某比较当前的工作目录h.txt文件已经被删除了,工作区目录和暂存区比较文件差异也可以返现文件删除模式。接下来删除暂存区目录


代码如下:

通过删除暂存区文件前后可以比较出文件的差异。此时文件也不在跟踪状态。还有我们仅仅希望删除暂存区的内容,不删除工作区的内容

代码如下:

移动
git移动文件操作是是相对先移动复制一个新文件,删除原文件,添加新文件到跟踪范围。

代码如下:

9、查看提交历史

代码如下:

com3
gitlog查看提交历史,gitlog-p-n最近n次提交的内能和差异。查看历史记录统计信息gitlog--stat,查看提交的历史记录格式可*选择。

代码如下:

列出了常用的格式占位符写法及其代表的意义。

选项说明
%h提交对象(commit)的完整哈希字串
%h提交对象的简短哈希字串
%t树对象(tree)的完整哈希字串
%t树对象的简短哈希字串
%p父对象(parent)的完整哈希字串
%p父对象的简短哈希字串
%an作者(author)的名字
%ae作者的电子邮件地址
%ad作者修订日期(可以用-date=选项定制格式)
%ar作者修订日期,按多久以前的方式显示
%cn提交者(committer)的名字
%ce提交者的电子邮件地址
%cd提交日期
%cr提交日期,按多久以前的方式显示
%s提交说明
$gitlog--pretty=format:"%h%s"--graph
*78d907adevbranchcommit
*fc0166ftestgitdiff
*d6eab3aenforcecommit'
*85ec024com3
*d4a498athisistestcommit
*80071e41stcommit

选项说明
-p按补丁格式显示每个更新之间的差异。
--stat显示每次更新的文件修改统计信息。
--shortstat只显示--stat中最后的行数修改添加移除统计。
--name-only仅在提交信息后显示已修改的文件清单。
--name-status显示新增、修改、删除的文件清单。
--abbrev-commit仅显示sha-1的前几个字符,而非所有的40个字符。
--relative-date使用较短的相对时间显示(比如,“2weeksago”)。
--graph显示ascii图形表示的分支合并历史。
--pretty使用其他格式显示历史提交信息。可用的选项包括oneline,short,full,fuller和format(后跟指定格式)


10、撤销操作

可以修改最后一次提交的内容,当你发现最近一次提交内容不正确时候,可以通过gitcommit--amend修改

代码如下:

11、取消文件修改

代码如下:

相关标签: Git