GIT教程 — 详解本地库的使用以及原理(二)

标签: git本地库的操作 GIT教程
896人阅读 评论(0) 收藏 举报
分类:

详解本地库的使用以及原理(二)





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

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

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

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

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其实最厉害的是与他人共享代码

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


查看评论

GIT教程 — 详解本地库的使用以及原理(一)

详解本地库的使用以及原理(一) 对于广大的windows程序开发大军,大家都会使用windows上面的git-bash客户端,本地的git客户端是不会离开git版本仓库的,因 ...
  • Dawn_sf
  • Dawn_sf
  • 2017-10-13 17:04:08
  • 1599

详解GIT远程库的创建、与本地库关联以及推送内容到远程库

GIT是一个分布式版本控制系统,这不同于CVS,SVN等集中式版本控制系统,同一个Git仓库,可以分布到不同的机器上,且每台机器上版本库是一样的没有主次之分。所以一般来讲需要至少两太电脑才能实验远程库...
  • whatever9527
  • whatever9527
  • 2016-12-02 15:22:48
  • 1316

掘金小册:Git 原理详解和实用指南

正如前两天公众号里说的,最近开启疯狂模式,和掘金合作,写了一本掘金小册。这本小册的名字是:《Git 原理详解和使用指南》。这本小册简单来说,是一本帮助那些始终学不会、学不好 Git 的人真正一次性学会...
  • LSpQ35k7O5AJ21l1H9o
  • LSpQ35k7O5AJ21l1H9o
  • 2017-11-30 00:00:00
  • 1351

TortoiseGit工具使用教程之一环境搭建

前段时间一直在写自己的毕业论文,实验室和宿舍来回跑,每次都是把论文拷贝到U盘里面,想想真是很麻烦。联想到自己前段时间做项目一直在用SVN(版本控制器),只用简单的提交和更新就能完成更改和复制操作,很方...
  • xiaoxiangshenjian
  • xiaoxiangshenjian
  • 2017-07-30 09:16:44
  • 300

海龟git操作教程

TortoiseGit 简称 tgit, 中文名海龟Git. 下载: 下载git(msysgit)和tortoisegit地址:http://rj.baidu.com/search/ind...
  • Ha_Pipi
  • Ha_Pipi
  • 2016-12-15 16:42:49
  • 1658

Git学习之路(二)——安装Git

说明最初,Git是用于Linux下的内核代码管理。因为其非常好用,目前,已经被成功移植到Mac和Windows操作系统下。鉴于我日常使用的是Windows操作系统,故,这里只详细讲解Windows操作...
  • hammer9173
  • hammer9173
  • 2016-05-26 09:04:06
  • 3114

git clone/版本库之间的push与pull

1. 目的:为了做一个备份,所以需要一个其它的版本库。    也就是git clone,然后通过git push 与 git pull实现两个版本库的同步。    语法:git push ...
  • u012150179
  • u012150179
  • 2013-12-09 19:56:27
  • 5522

git学习二:git初级使用教程

对初学者,首先要了解下git基本操作:如创建自己git并把本地代码上传至github上,git初识化配置。...
  • u014079773
  • u014079773
  • 2015-11-01 08:47:08
  • 4367

git使用培训教程

  • 2017年11月06日 21:44
  • 12.79MB
  • 下载

《Git 原理详解及实用指南》阅读笔记

用于记录阅读 Git 原理详解及实用指南 之后的笔记备忘。 git merge some_branch 的意思是将 some_branch 这一分支与 HEAD 指向的某一分支合并, HEA...
  • OneDeveloper
  • OneDeveloper
  • 2018-03-17 23:11:15
  • 89
    个人资料
    持之以恒
    等级:
    访问量: 11万+
    积分: 3173
    排名: 1万+
    最新评论