文章目录

  • Git是什么?
  • 集中式vs分布式
  • 创建git版本库
  • 往仓库添加文件
  • 暂存区与工作区
  • 移出缓存区的文件
  • 修改文件
  • 版本回退
  • 撤销修改
  • 删除文件

详情

Git是什么?

引用廖雪峰的话:

Git是目前世界上最先进的分布式版本控制系统(没有之一)。

Git有什么特点?简单来说就是:高端大气上档次!

集中式vs分布式

先说集中式版本控制系统,版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。

那分布式版本控制系统与集中式版本控制系统有何不同呢?首先,分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了

在实际使用分布式版本控制系统的时候,其实很少在两人之间的电脑上推送版本库的修改,因为可能你们俩不在一个局域网内,两台电脑互相访问不了,也可能今天你的同事病了,他的电脑压根没有开机。因此,分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已

集中式代表的有 CVS,SVN;

分布式有:Git, BitKeeper,Mercurial,Bazaar;

创建git版本库

git init

此时 仓库已经创建完毕,我们会发现文件夹内多了一个.git 文件夹,如果你没有看到.git目录,那是因为这个目录默认是隐藏的,用ls -ah命令就可以看见,
或者在文件夹内 勾选隐藏项目显示;

往仓库添加文件

我们先使用指令查看当前仓库的状态

git status

此时会显示你所有添加的文件与没有添加文件,如果没有显示,需要将文件夹添加到定义仓库的文件夹内,在使用一边指令。

接下来我们需要将文件添加到仓库中,需要使用下面的指令进行操作

git add <file>  //文件或者文件夹名称;

你会发现此时并没有任何提示信息,在git中没有信息就是最好的信息;
我们在使用指令查看一下仓库的状态,你会发现此时文件已经添加到仓库中

暂存区与工作区

什么是工作区?

顾名思义,就是我们真正边编写代码的文件和文件夹,.git不能归纳其中,因为他是而是Git的版本库。

什么是暂存区?

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

此时仓库所添加的文件并没有真正意义上添加到版本管理工具中,而是添加到git仓库中的暂存区,我们需要提价来添加到git仓库管理工具中,此时我们就需要另一个指令。

git commit -m "提示信息"

前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:

第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;

第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
此时我们成功添加到仓库中 如果添加失败,可能你还没有配置账号和邮箱:

请使用下面这两个指令,配置属于你的账号和邮箱

git config --global user.name xxx
git config --global user.email xxx@163.com

然后我们可以使用指令查看日志文件

git log


此时又涉及到HEAD和master

这个以后在学习,我们先学习基本操作,感兴趣的可以访问廖雪峰的网站里面有更为丰富的文章和视频 详情

移出缓存区的文件

在没有进行提交commit 的文件 我们可以使用下面指令,将文件从缓存区中移出

git reset HEAD <flie>

修改文件

如果我们第一次将文件添加到缓存区,并没有直接提交到仓库中,我们有再次修改文件,然后使用了commit 进行提交,此时我们提交的是放入缓存区里面的文件并非修改后的文件,如果想提交修改后的文件,需要重新执行add命令再次提交;

版本回退

我们将修改的文件提交之后,使用log指令会显示提交的日志,加入我们提交之后是个错误的版本,但你发现及时,此时我们可以使用版本回退,将版本回退到其中上一个日志中,我们需要获取日志版本号和下面指令

git reset --hard 版本号    //可以不用完全写完整;

版本号使用log指令查看,执行完毕后我们的代码就回到了你指定的版本中,
如果你后悔了,只要命令行不管 我们使用版本回退也可以回退到之前的版本;
使用你之前的指令 将版本号写成你回退之间的版本号,再次回到之前的版本中

如果你已经关闭命令 并不知道commit id 没关系 git 可以有后悔药 我们使用下面指令 获取你曾经输入的指令

git reflog

里面有你曾经提交过的commit id 再次使用版本回退。

撤销修改

如果你在写代码的时候 在没有使用add的情况下 将代码撤销到你上次提交或者add中 我们可以使用下面的指令 将代码回到修改前

git checkout -- <file>

如果此时你add添加到暂存区,我们也可以使用上面的指令,git reset HEAD ,将文件从暂存区回退到工作区,再次使用指令,将代码撤销;

如果此时你页已经经代码提交,就需要使用版本回退,

删除文件

我们可以使用下面指令删除文件或者手动删除;

git rm <file>

然后提交就可以将文件删除

这么多指令 是不是头都大了,我们也可以使用乌龟壳进行状态管理

下载

安装完成之后 鼠标右键会有多出三个选项

我们就可以直接使用不用使用指令修改了

git与乌龟壳git相关推荐

  1. Git 常用操作(5)- git clone/git checkout -b/git diff/git push/git pull

    1. git clone--获取远程仓库 当 git fetch 命令从服务器上抓取本地没有的数据时,它并不会修改工作目录中的内容.它只会获取数据然后 让你自己合并. 然而,有一个命令叫作 git p ...

  2. git clean和git reset结合用法

    git clean命令用来从你的工作目录中删除所有没有tracked过的文件 git clean经常和git reset --hard一起结合使用. 记住reset只影响被track过的文件, 所以需 ...

  3. git用户文档1 — git基础

    1. git基础 1.1 分布式 我们把远端仓库(云端的仓库)称为repo,repo必须有一个master分支,就是主分支. repo除了有一个master分支,还有很多其他的分支,若干个分支之间存储 ...

  4. Git fetch和git pull的区别

    原文:http://www.tech126.com/git-fetch-pull/ Git中从远程的分支获取最新的版本到本地有这样2个命令: 1. git fetch:相当于是从远程获取最新版本到本地 ...

  5. HbuilderX中的git的使用 git HbuilderXgit HbuilderX 使用git

    [前戏]:得在HubilderX中找到  "工具"->"插件安装" -> "Git插件" . [提交代码]:(1)选中该项目的文 ...

  6. git rebase 和 git merger

    & git merge 在上图中,每一个绿框均代表一个commit.除了c1,每一个commit都有一条有向边指向它在当前branch当中的上一个commit. 图中的项目,在c2之后就开了另 ...

  7. git init 与 git init --bare 区别

    git init 与 git init --bare 区别 发现问题 最早是在公司的wiki上发现了这个命令,google后发现值得记录下来 实践中发现的区别 网上找了很多资料,但说的很乱,干脆在自己 ...

  8. git:Git fetch和git pull的区别, 解决Git报错:error: You have not concluded your merge (MERGE_HEAD exists)....

    Git fetch和git pull的区别, 解决Git报错:error: You have not concluded your merge (MERGE_HEAD exists). 解决办法一:保 ...

  9. git push VS git fetch

    最近我们研发团队所有项目源码的版本管理实现了统一化,全部统一采用git进行管理,丢弃svn.在使用git的过程中,遇到了git pull和git fetch两个命令,针对具体含义与区别比较模糊,进而进 ...

  10. git服务器查看用户信息,git 查看当前git用户_新Git用户使用方法

    git 查看当前git用户 This post is a tutorial for new users to set up git and clone and use the first reposi ...

最新文章

  1. golang中的strings.ContainsRune
  2. 机器学习笔记:RMSProp,Adadelta
  3. footer bar in SAP Fiori as a service
  4. 虚拟计算机组成,计算机组成原理虚拟仿真实验平台研究
  5. ASP.NET实现页面传值的几种方法
  6. rest syntax(parameters)
  7. 公钥,私钥,数字签名,证书
  8. element中的table相关
  9. 阿里、腾讯决战商业“OS”
  10. 一些音视频相关概念学习笔记
  11. 中国电信中国电信物联网开放平台-连接管理子系统 http返回为空
  12. python sleep函数什么意思_python中sleep函数用法实例分析
  13. 使用python实现的天眼查小工具
  14. (求助)RPC failed;curl 56 GnuTLS recv error(-9): A TLS packet with unexpected length was received
  15. win10user文件夹迁移_win10专业版用户文件夹迁移到另一个驱动器的方法
  16. memcpy()详解
  17. HTML 通过GIF实现loading动画(非进度条版)。
  18. 惠誉接力唱空中资股 国企红筹股为观察重点
  19. 区块链技术精华:四十种智能合约支持平台(四)
  20. 移动互联网,一场思维与市场的变革

热门文章

  1. 计算机与软件水平考试中级,2020年计算机软件水平考试可以直接考中级吗
  2. LaTeX最全的数学符号大全(更新中…… )
  3. 奇怪的 Win10 输入法问题
  4. python3 json文件_Python3读写JSON文件
  5. python之pygame,详解坦克大战
  6. ev3编码软件linux,乐高ev3编程软件下载
  7. (转发)详解汽车UDS诊断协议(一)
  8. 微信小程序商城毕业设计毕设作品(8)毕业设计论文
  9. Docker下载Nginx镜像并运行Nginx容器
  10. 2021年顶级服务器备份软件和解决方案