Git简单学习

Git简介部分

      问:git是什么?

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

      问:分布式版本控制系统和集中式版本控制系统的区别?

      答:对于集中式版本控制系统 版本库是存放在中央服务器的,我们每个人要工作的时候都要从中央服务器中拿到最新的版本,开始干活,干完活之后再将其推送至中央服务器。

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

             其实在实际工作中,分布式版本控制系统也是有中央服务器的,不过这个中央服务器是为了更方便大家之间修改的交换,没有这个中央服务器大家一样能够工作,不像集中式版本控制系统,一旦中央服务器崩溃,那么大家就都干不了活。

 

注:提前在此说明,如果我们需要将项目传至自己的github中,那么我们首先本地就需要安装一个Git,才能进行此操作。此时Github就相当于一个分布式版本控制系统中的中央服务器。

 

此次Github全程学习,主要借鉴于:https://www.liaoxuefeng.com

 

创建版本库

 版本库可以理解为一个仓库,仓库中存储的东西都被Git监听这,Git能够记住它入库之后的所有改变吗,并将其作为同一文件的不同版本,Git能够对其进行版本之间的各种操作,因此称之为版本控制系统。

说明一下,所有路径不要使用英文。

另外不要使用Windows自带的记事本进行编辑,建议使用NotePad++,免费的,具体原因可自行百度

下面我们就来创建版本库:

 此界面是Windows的GitBash中的页面,GitBash就相当于Git的黑窗口,在安装Windows版的Git时自带。其中各种命令和Linux差不多。

pwd 展示当前路径 (其实图中黄色字体就为所在路径)

mkdir 创建文件夹

git init 将所在目录的文件夹设置为版本库(会在所在目录中创建一个.git文件,默认是隐藏文件),这个目录不要乱动乱改

添加文件至版本库

新建一个文件到版本库所在目录下,内容如下:

Git is a version control system.
Git is free software.

然后使用命令:

$ git add test1.txt        此命令执行完之后没有任何提示即为正确

$ git commit -m "wrote a test1 file"          此命令执行完之后,显示下面内容
[master (root-commit) c1a689e] wrote a test1 file
 1 file changed, 2 insertions(+)
 create mode 100644 test1.txt                       1 file changed代表了一个文件改变了,2insertions(+)代表文件中有两行插入
 注:add命令可进行多次后,再进行commit将所有add一次性提交

版本之间的管理

版本回退

我们现在已经有了一个test1.txt了,我们用notepade++将其内容更改为:

Git is a distributed version control system.
Git is free software.

运行命令:git status    顾名思义:git的状态

提示信息告诉我们,我们的test1.txt文件已经更改了,但是还没有进行add和commit操作

运行命令:git diff test1.txt  就能够查看我们test1.txt文档进行了什么更改

如果我们现在需要将更改提交到版本库,那么我们就得add和commit命令

为了让我们接下来的版本区别看起来更加明显,我们再对test1.txt进行一次更改,进行提交版本库

改为:

Git is a distributed version control system.
Git is free software distributed under the GPL.

 

运行git log命令显示从最近到最远的提交日志,我们可以看到已经有了3次提交

commit后面跟的就是每个版本的版本号,是一大串16进制的数字,Svn中则是1,2,3...递增的数字

途中(Head->master)代表的就是这个为我们当前的版本 ,Head^代表上个版本,Head^^代表上上个版本,Head~100代表100个之前的版本

$git reset --hard Head^   代表返回上一版本,接着调用$git log 发现最后一个的版本的信息已经不见了,我们往上翻看到上一个的版本号,$ git reset --hard 4db5b91即可返回到指定版本,版本号不用写全,有唯一性就行,但是我们如果关掉了GitBash页面就没法往上翻了,这时候我们就可以运行$ git reflog ,可以查看我们之前的命令历史。

工作区和暂存区

工作区:我们的gittest1就是一个工作区

版本库:工作区gittest1有一个隐藏目录.git,这个就是Git的版本库。

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

add命令就是我们将文件从工作区提交到暂存区,commit就是我们将文件从暂存区存放到分支中

介绍几个手贱之后用来撤销的命令:

$git checkout -- test1.txt    将test1.txt文件状态返回值最近一次add或者commit的状态

$git reset HEAD <file>  此命令意思是回退至哪次版本,也就是说如果我们将错误已经add进去了,那么这时候我们可以调用此方法,将暂存区的数据进行清空,然后再调用checkout命令,就能将工作区的文件还原和分支中最新版本相同的状态

 

如果我们对文件进行了删除操作,那么status就会告诉我们我们删除了这个文件,如果我们需要再版本库中删除,那么我们就要git rm test1.txt 然后commit就成功了,不过如果我们反悔了,也可以通过更改版本去拿回这个文件

如果需要学习分支管理可以去:https://www.liaoxuefeng.com

在最后,如果我们需要用Idea配置GitHub可参考https://www.cnblogs.com/javabg/p/7987755.html

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值