git 基础最详细使用教程

1. git的两大特点

  • 版本控制:可以解决多人同时开发的代码问题,也可以解决找回历史代码的问题。
  • 分布式:Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上。首先找一台电脑充当服务器的角色,每天24小时开机,其他每个人都从这个“服务器”仓库克隆一份到自己的电脑上,并且各自把各自的提交推送到服务器仓库里,也从服务器仓库中拉取别人的提交。可以自己搭建这台服务器,也可以使用GitHub网站。

2. 安装与配置

(1) 安装命令如下:

	sudo apt-get install git

(2) 安装成功后,运行如下命令:

	git

安装成功显示效果如上

3. 创建一个版本库

(1) 新建一个目录git_folder,在git_folder目录下创建一个版本库,命令如下:

	git init

在这里插入图片描述

  • 可以看到在git_folder目录下创建了一个.git隐藏目录,这就是版本库目录。

(2)配置个人信息

git config --global user.name
git config --global user.email

4. 版本创建与回退

4.1 使用

(1) 在git_folder目录下创建一个文件first.txt,编辑内容如下:

	this is myfirst data

在这里插入图片描述
(2) 使用如下两条命令可以创建一个版本

	git add first.txt
    git commit -m '版本1'

在这里插入图片描述
(3) 使用如下命令可以查看版本记录:

	git log

在这里插入图片描述
(4) 继续编辑first.txt,在里面增加一行。

	this is my second data

在这里插入图片描述
(5) 使用如下命令再创建一个版本并查看版本记录:

	git add first.txt
    git commit –m '版本2'

在这里插入图片描述
(6) 再使用如下命令查看版本记录:

	git log

在这里插入图片描述
(7) 现在若想回到上一个版本(版本1),可以使用如下命令:

	git reset --hard HEAD^

在这里插入图片描述
(8) 现在我们再去查看版本库,看看是否回到了上个版本(版本1),同时查看文件内容,看是否将第二次我们添加的内容清除了。

	git log

在这里插入图片描述

  • 我们可以看到,发现现在只能看到版本1的记录,说明版本已经退回,同时添加的内容也被清除了,只剩下也第一个版本中的数据。

说明

  • HEAD表示当前最新版本
  • HEAD^ 表示当前版本的前一个版本,HEAD^^表示当前版本的前前个版本
  • 也可以使用HEAD~ 1表示当前版本的前一个版本,HEAD~100表示当前版本的前100版本。

(7) 假如我们现在又想回到版本2,这个时候怎么办?

	git reset --hard 版本号

在这里插入图片描述

  • 我们发现通过git log查询版本记录时,已经找不到版本2的记录,所以此时我们需要以下命令:
	git reflog

在这里插入图片描述

  • 此时我们可以看到版本2的版本号了,使用以下命令回到版本2:
	git reset --hard ca3a776

在这里插入图片描述
4.2 工作区和暂存区

  • 4.2.1 工作区(Working Directory)
    电脑中的目录,比如我们的git_folder,就是一个工作区。

  • 4.2.2 版本库(Repository)
    工作区有一个隐藏目录.git,这个不是工作区,而是git的版本库。
    git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。
    因为我们创建git版本库时,git自动为我们创建了唯一一个master分支,所以,现在,git commit就是往master分支上提交更改。
    你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。

在这里插入图片描述
前面讲了我们把文件往git版本库里添加的时候,是分两步执行的:
第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区
第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支

(1) 下面在git_flodet目录下再创建一个文件second.txt,然后编辑内容如下:

	this is my first data

在这里插入图片描述
(2) 然后再次编辑first.txt内容,在其中加入一行,编辑后内容如下:

	this is my third data

在这里插入图片描述
(3) 使用如下命令查看当前工作树的状态:

	git status

![在这里插入图片描述](https://img-blog.csdnimg.cn/20190214151522701.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQyNTE3MjIw,size_16,color_FFFFFF,

  • 上面提示我们first.txt被修改,而second.txt没有被跟踪。

(4) 我们使用如下命令把first.txt和second.txt加入到暂存区,然后再执行git status命令,结果如下:

	git add first.txt 
	git add second.txt 
	git status

在这里插入图片描述

  • 所有git add命令是把所有提交的修改存放到暂存区。

(5) 然后,执行git commit就可以一次性把暂存区的所有修改提交到分支创建一个版本。

	git commit -m "版本3"

在这里插入图片描述

(6) 一旦提交后,如果你又没有对工作区做任何修改,那么工作区就是“干净”的。执行如下命令可以发现:

	git status

在这里插入图片描述

  • 现在我们的版本库变成了这样:
    在这里插入图片描述

4.3 管理修改

git管理的文件的修改,它只会提交暂存区的修改来创建版本(即 commit 只对 add 过的文件生效)

(1) 编辑first.txt,并使用git add 命令将其添加到暂存区中。

	git add

在这里插入图片描述
(2) 继续编辑first.txt,并在其中添加一行。

	this is my new data

在这里插入图片描述
(3) git commit创建一个版本,并使用git status查看,发现第二次修改first.txt内容之后,并没有将其添加的工作区,所以创建版本的时候并没有被提交。

	git commit -m "版本4"

在这里插入图片描述
4.4 撤销修改

(1) 继续上面的操作,提示我们可以使用 git checkout – <文件> 来丢弃工作区的改动。执行如下命令,发现工作区干净了,第二次的改动内容也没了。

	git checkout -- first.txt

在这里插入图片描述
(2) 我们继续编辑first.txt,并在其中添加如下内容,并将其添加的暂存区。

	second add this is my new data

在这里插入图片描述
(3) git同样告诉我们,用命令git reset HEAD file可以把暂存区的修改撤销掉,重新放回工作区。

	git reset HEAD first.txt

在这里插入图片描述
(4) 现在若想丢弃first.txt的修改,执行如下命令即可。

	git checkout -- first.txt

在这里插入图片描述

总结

  • 当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file
  • 当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步用命令git checkout -- file,就回到了修改前
  • 已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节。
  • 工作区:可进行两种操作:
  • 第一:使用git add file将文件修改提交到暂存区,然后提交分值形成版本
  • 第二:使用git chectout -- file 放弃修改
  • git add file:将工作区改动提交到暂存区
  • git commit -m “说明”:将暂存区内容合并到分支,形成新版本

4.5 对比文件的不同

  • 对比工作区和某个版本中文件的不同:

(1) 继续编辑文件first.txt,在其中添加一行内容。

	third add this is my new data

在这里插入图片描述
(2) 现在要对比工作区中first.txt和HEAD版本中first.txt的不同。使用如下命令:

	git diff HEAD -- first.txt

在这里插入图片描述
(3) 使用如下命令丢弃工作区的改动。

	git checkout -- first.txt

在这里插入图片描述

  • 对比两个版本间文件的不同:

(1) 现在要对比HEAD和HEAD^版本中first.txt的不同,使用如下命令:

	git diff HEAD HEAD^ -- first.txt

在这里插入图片描述

4.6 删除文件

(1) 我们把目录中的second.txt删除。

	rm second.txt

这个时候,git知道删除了文件,因此,工作区和版本库就不一致了,git status命令会立刻提示哪些文件被删除了。
在这里插入图片描述
(2) 现在你有两个选择

  • 一是确实要从版本库中删除该文件执行以下命令
	git rm second.txt
	git commit -m "删除文件second.txt"

在这里插入图片描述

  • 另一种情况是删错了,可以直接使用以下命令进行恢复
	git checkout -- second.txt

小结:

  • 命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值