您可以捐助,支持我们的公益事业。

1元 10元 50元





认证码:  验证码,看不清楚?请点击刷新验证码 必填



  求知 文章 文库 Lib 视频 iPerson 课程 认证 咨询 工具 讲座 Model Center   Code  
会员   
   
 
     
   
 订阅
  捐助
详解本地库的使用以及原理(二)
 
来源:csdn 发布于: 2017-11-3
   次浏览      
 

我们在上一个详解本地库的使用以及原理(一)当中了解到,如何创建一个本地库,然后查看本地库的修改,以及有本地库的各个版本之间的切换.

还有本地库的版本记录的原理. 接下来这个博客,我们来了解本地库的底层实现原理>>> 工作区和版本库

什么是工作区和暂存区呢????

工作区就是你电脑当中所有可以看到的任意一个目录,可以这样理解这些目录是属于你工作的所以你可以看到他们.它们都要被你一直使用.

GIT的版本库:在一个工作区里面的会有.git的隐藏目录,这里就已经不属于工作区了,这里是git的版本库.这里就是保存你需要往git推送的内容.

Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指

向master的一个指针叫HEAD. 这里的HEAD指针我们已经见识过一点了,但是分支是非常重要的!但是现在我们不关心! 我们关心的是暂存区....

上图其实就是我们从工作区将文件推送到git分支上的具体过程,现在我们应该理解到了为什么需要git add和git commit两步才能推送成功了吧~

git add 将文件从工作区推送到暂存区. git commit将所有的暂存区的内容推送到master.因为我们创建Git版本库时,Git自动为我们创建了唯一一个

master分支,所以,现在,git commit就是往master分支上提交更改。你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂

存区的所有修改。 我们明白了这些,接下来理解很多git的操作之后就会得心应手了~

所以当你修改一个文件之后,如果你没有git add. 你直接git commit是没有任何作用的. 记住你可以很多次git add 然后使用一次git commit~

git本地库的撤销修改

我们生活当中,不管是微信还是qq都有一个撤回的功能,原因就是我们发了一些不该发的东西,比如你跟你的基友发送一些不健康的东西(微笑) 然后

你猛然发现发到女朋友的qq上面了,这时候趁女朋友没有发现赶紧撤回!!! 所以这个功能发明的就非常合情合理. 那么GIT怎么会没有这些操作呢?

其实GIT也有类似的功能,就是防止你修改文件出错,然后非常后悔,再然后只需要一条指令就恢复如初. 接下来我们来认识一下:

$ git checkout -- file(这里是你的文件名)

这里我发现我的liang.txt里面出现了脏话,当然我可以里面回文件里面删掉,但是这里我要秀操作哈哈.我们可以看到这里一句指令撤销了上一条内容

但是如果你不幸git add,把文件推送到暂存区了怎么办?? 这里也不用担心~,看下面操作:

什么鬼...以前方法已经没有用了. 已经被添加到暂存区了怎么办.. 其实我们还有办法! 我可以使用指令把暂存区的文件回退到工作区,然后再撤销内

容,接下来我来演示一下:

我们可以这里看到,使用git reset HEAD file 指令可以使得暂存区当中的内容回退到工作区!!! 来继续,这个时候你发现你已经git commit 那么

这可怎么办! 上个博客当中的版本回退是干啥的?? 直接使用版本回退不就完了! 哪里来这么多话.。。。。

最后的最后,如果你把这个fuck you! 推送到远程库,推送到网上之后,那么你就自求多福吧.. 这个已经没有办法了.............

git本地库的删除文件

我们刚刚了解到了,撤销功能. 现在我们继续学习,学习删除功能这时候有的人就开始疑惑了... 这删除功能有啥删的,这就是最简单的rm 文件

就结束了. 不不不,当你单纯的删掉了一个文件,你使用git status指令时,他会告诉你版本库当中那个文件被删除了,所以你还需要在版本库

当中删除掉这个文件,所以我演示一下~

这个时候liang.txt,就永远不会出现在你的版本库和你的工作区当中了. 当然如果你发现自己误删的时候,一定注意我们还可以使用撤销功能.

如果当你在库中删除文件并且git commit了,我们还可以解决.因为我们有时光机,可以回到过去~~ 所以这里我们可以看到git的强大之处.

大概功能就这么多,还是希望大家好好努力.好好练习这个git的本地库的基本操作. 还有分支是非常重要的. 因为git其实最厉害的是与他人共享代码

,大家一起合同协作,所以接下来分支和网上的远程库,以及和他人合作都是非常重要的.

   
次浏览       
相关文章

每日构建解决方案
如何制定有效的配置管理流程
配置管理主要活动及实现方法
构建管理入门
相关文档

配置管理流程
配置管理白皮书
CM09_C配置管理标准
使用SVN进行版本控制
相关课程

配置管理实践
配置管理方法、工具与应用
多层次集成配置管理
产品发布管理