首页 > 其他 > 详细

Git的简单使用

时间:2018-06-26 23:29:24      阅读:310      评论:0      收藏:0      [点我收藏+]

  这是我第二篇关于git使用的文章,承袭上一篇文章《git基本概念以及简单用法》地址是:https://www.cnblogs.com/lizhe-Ning/p/9162242.html

  先说两句题外话,今天看到一位老师写的文章,内容相似。但是人家的文章一看就条理鲜明,思路清楚,格式工整规范。如果我是一个求助者,肯定喜欢读他的文章。这是我以后学习的对象与目标。我把他的链接贴出来希望能够帮助大家。http://bioinfostar.com/2018/06/15/%E5%AD%A6R%E5%AD%A6%E5%88%9D%E9%98%B6-03-R-Git%E5%92%8CGithub-1/,转载的时候才发现这位老师也是转载其他人的,为了避免间接引用我直接给出原作者的链接。

 

  以下是我的笔记!!辣眼睛。我会改的,加油!!!!!!

  PS:新学会了一个技能:在命令行中使用ls可以查看目录中包含可见子目录,与dir效果相似。使用ls -a命令能看到隐藏的目录。

技术分享图片

 

 

Git文件

git资源库与普通文件夹不同之处就是,其中保存了自资源库创建以来资源库历史相关的元数据。以.git文件格式保存,通常情况下为隐藏目录。

 

初始化git仓库git init

在相应的目录输入命令git init,即可以初始化或者新建一个git仓库。新创建的git仓库中没有任何的commit。例子见图二。

 

技术分享图片

图二初始化仓库示例

因为我创建的新目录是version-control路径下的recipes,所以我转到该目录下使用git init命令,初始化一个新的git库。(PS:该目录中已经包含三个文件了,分别是cake.txtchili.txtfrosting.txt,三个文件。)

 

Git 的版本库和目录

每个 Git 版本库均关联到一个特定目录,即你运行了 git init 的目录。版本库仅包含该目录及其子目录中的文件,而且不同的版本库位于不同的目录中。简单点说就是文件的版本库储存在文件所在的目录中。

注意:你经常会看到,某个目录中的 Git 版本库仅包含或仅跟踪该目录中的某些,而不是所有文件。这是被允许的。因为可能发生改变的只有几个文件,其他文件没有发生变化。

状态命令 git status

git status:可以获得git仓库状态,仓库中有哪些文件,是否被追踪,有多少个commit,是否有初始commit

技术分享图片

图三状态命令的使用

从图中可以发现,新建的git目录中没有任何提交,并且没有被追踪的文件,有三个未被追踪的文件。

添加到储存区命令 git add

git add:将文件添加到储存区的命令。文件添加到git仓库机理:git会使用一个临时储存区的空间,文件先逐个进入该区域,添加到该区域后文件可以被打包commit

技术分享图片

图四添加到储存去命令

删除命令 git reset

git reset:删除暂存区中的文件。例如,如果你意外地添加了 lesson_2_reflections.txt,但不想提交它,请运行 git reset lesson_2_reflections.txt,此命令会从暂存区中删除该文件,但它仍在你的工作目录中。

特别的,git reset --hard HEAD~1命令可以删除最近一次commitgit rest --head 命令放弃工作区和暂存区中所有更改!谨慎使用,因为没有办法撤回。

 

技术分享图片

图五删除命令示例

提交命令 git commit

使用git commit命令可以提交暂存区中的内容。使用git commit命令会打开默认的提交信息编辑器,在其中编辑commit信息。一般使用祈使句。

技术分享图片

图六提交命令示例

比较命令 git diff

git diff命令:"git diff ID1 ID2"命令可以比较两个commit之间的区别,这在上节课中讲过。其实,

?  “git diff”(不加任何参数)命令可以比较工作区和文件暂存区(使用git add之后的文件)文件的不同,修改文件会在工作区进行修改,最新的更改没有提交到暂存区前,暂存区中存储版本库中最近的commit的副本。

?  “git diff --staged”命令可以比较暂存区和版本库中文件的区别。

 

分支命令 git branch

当只是修改bug时线性结构足已完成任务,如果想要实验一个新的功能,就可以创建分支。

分支分为两种:master分支,仓库中的主要分支,每次创建一个git仓库时就会创建一个maser分支;其他分支,因为其他目的创建的分支。

Git branch:创建和查看分支。

1.         当不带任何参数时,显示当前分支;

2.         以名字为参数时,可以创建一个新的分支;

3.         git checkout -b new_branch_name:同时创建新的分支并且转到新的分支去。

技术分享图片

图七 git branch命令示例

master分支旁边的星号代表是当前检出分支。同样可以使用checkout 加分支名命令可以转到相应的分支。

技术分享图片

图八 git branch命令使用示例

在分支中进行的操作和在master分支中相同。如果提交成功的话,会有如下显示:

技术分享图片

图九提交成狗界面

PS:我在easy-mode分支中,提交了一个commit。提交后第一行显示说明文件,第二行显示修改内容。最后使用git status命令查询状态时发现显示没有要提交的文件,工作区没有文件。因为修改的文件已经被提交了。

如果删除某个分支并导致无法从现有的分支访问一些提交,则在 Git 的垃圾收集过程运行之前,仍可继续通过提交 ID 访问这些提交。除非你主动关闭此过程,否则它将不时自动运行。也可以通过命令 git gc 手动运行此过程。

Git分支结构日志

git log --graph:使用该命令直观的查看分支结构;--oneline:使输出更短。使用这些命令时后面加上分支名,以明确可视化内容。

git只是记住每一个commitID和他们父节点,在检出(checkout)提交处不断向上寻找父节点,直到根节点。所以如果有版本分支的话,检出节点是分支中的节点,那么一定会有一些节点无法达到。这些节点是在该检出节点不可访问的。比如其他分支中的节点。

合并

        将两个版本合并时遵循以下规则:

?  不同版本中都存在的部分一定保存;

?  一个版本中存在,另一个版本中不存在,且原始版本中不存在(即新加入的特性)应该得到保留;如果一个版本中存在,另一个版本中不存在,且原始版本中存在(即某一个版本因为某些原因删去该部分),这部分应该删去;

?  如果在两个版本中都存在但是内容存在差异,这时候会提示内容冲突(CONFLICT(content)),这时候需要手动来选择到底保存哪个。

打开有冲突的文件git会使用类似的标记标出不同代码段。并告知他们属于哪个分支,在这里进行修改,之后删除特殊的git行即可。

 

技术分享图片

图十显示内容冲突后代开冲突文件显示画面

 

在没有修改冲突之前,使用git status会得到以下结果

技术分享图片

图十一存在冲突时git状态

     both modifie表明文件被修改了两次,两个分支都修改了文件由此产生了冲突

档把修改后的文件提交到暂存区后在使用git status命令得到

技术分享图片

图十二保存到暂存区后git状态

图十二表明冲突已经被修复,现在仍然在合并中,使用命令git commit可以继续合并。

两个分支合并就是用两个分支中信息重新创建一个commit,新的commit的父提交是被合并的两个commit。所以对合并后的commit使用git log会显示两条分支上所有的commit,他们按照时间顺序排列。

合并命令 git merge

git merge branch1 branch2:合并两个分支。

要注意,在合并的版本中会包含当前检出的分支。因此,如果检出了 branch1,并且运行 git merge branch2 branch3,则合并的版本会将 branch1 以及 branch2 branch3 组合起来。由于在你进行合并提交后 branch1 标签将会更新,因此,你不想将 branch1 中的更改包含在合并中是不可能的。有鉴于此,在合并之前应始终检出你打算合并的两个分支之一。应检出哪个分支取决于你想让哪个分支标签指向新的提交。由于检出的分支始终包含在合并中,因此,你可能已猜到,在合并两个分支时,无需在命令行上将两者都指定为 git merge 的参数。如果想将 branch2 合并到 branch1 中,只需键入 git checkout branch1,然后键入 git merge branch2 即可。键入 git merge branch1 branch2 的唯一原因是,它能帮助你对要合并的分支更加心中有数。

 

另外,由于是合并两个分支,因此在命令行中按何顺序键入分支并不重要。关键是要记住,git merge 始终将所有指定的分支合并到当前检出的分支中,并为该分支新建一个提交。

当我使用git merge进行合并时,出现了错误,

技术分享图片

图十三内容冲突

解决方法:

                                      i.            运行 git merge --abort,将文件恢复到你开始合并之前的状态

                                    ii.            仔细检查文件的状态。如果在检出 master 分支时运行 git log

                                  iii.            在文件处于正确的状态后,利用你所做的更改新建一个提交。

                                   iv.            重新尝试合并。

真的是经历了几十次尝试才成功。有以下几个要点:

1.       文件一定不能使用tab,一定要用空格来调整格式。

2.       使用windows系统时需要设置git config --global core.autocrlf true。详情参考:https://help.github.com/articles/dealing-with-line-endings/#platform-all

3.       合并前一定要注意现在在那个分支中,有可能修改文件后,进入系统默认的创建的临时分支中,我就是这样老是失败。如果发现要合并分支最近的commit不是想要的,或者是错的。使用”git reset --hard HEAD~1“删除最近的commit,然后直接在分支下修改,提交,然后进行合并。(修改时切记不要检出某个commit然后修改,提交。这样新的commit不会保存在原分支中,而是储存在新建的一个临时分支中。)

技术分享图片

 

终于成功了!!!开心。还有一点就是merge同样会让你写说明文档,但是其实里面已经有内容了,即合并了。。。分支

与父级进行对比 git show

刚刚已经说了,合并之后所有的commit按照时间顺序排列,这真的不好,没法直接找到某一个commit的父版本,不利于比较和修改。基于此我们可以使用两种办法:

1.       删掉某一个分支中的所有标签。git branch dash d coins(分支名)。他不会删除分支中的提交,只会删除标签,这样的话很难找到他们

2.       git show git show command_id命令直接返回command_id提交与其父版本的区别。

 

 

在命令行中使用ls可以查看目录中包含可见子目录,与dir效果相似。使用ls -a命令能看到隐藏的目录。

Git的简单使用

原文:https://www.cnblogs.com/lizhe-Ning/p/9231677.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!