文章目录
- 一、Git初识
- [二、Git的安装 - CentOS](#二、Git的安装 - CentOS)
- 三、Git基本操作
-
- [1. 创建Git本地仓库](#1. 创建Git本地仓库)
- [2. 配置Git](#2. 配置Git)
- [3. 认识工作区、暂存区、版本库](#3. 认识工作区、暂存区、版本库)
- [4. 版本回退](#4. 版本回退)
- [5. 撤销修改](#5. 撤销修改)
-
- 情况1:对于工作区的代码,还没有add
- [情况二:已经add ,但没有commit](#情况二:已经add ,但没有commit)
- [情况三:已经add ,并且也commit 了](#情况三:已经add ,并且也commit 了)
- 删除文件
一、Git初识
git本质上是一个版本控制器
为了能够更方便我们管理不同版本的文件,便有了版本控制器。所谓的版本控制器,就是能让你了解到一个文件的历史,以及它的发展过程的系统。通俗的讲就是一个可以记录工程的每一次改动和版本迭代的一个管理系统,同时也方便多人协同作业。
目前最主流的版本控制器就是 Git 。Git 可以控制电脑上所有格式的文件,例如 doc、excel、dwg、dgn、rvt等等。对于我们开发人员来说,Git 最重要的就是可以帮助我们管理软件开发项目中的源代码文件!
二、Git的安装 - CentOS
安装 Git:
bash
sudo yum -y install git
查看git的版本:
bash
git --version
三、Git基本操作
1. 创建Git本地仓库
创建一个 Git 本地仓库对应的命令为 git init
,注意命令要在文件目录下执行,例如:
bash
hyb@139-159-150-152:~/gitcode$ pwd
/home/hyb/gitcode
hyb@139-159-150-152:~/gitcode$ git init
Initialized empty Git repository in /home/hyb/gitcode/.git/
hyb@139-159-150-152:~/gitcode$ ll -a
total 12
drwxrwxr-x 3 hyb hyb 4096 May 5 15:49 ./
drwxr-xr-x 13 hyb hyb 4096 May 5 15:47 ../
drwxrwxr-x 7 hyb hyb 4096 May 5 15:49 .git/
2. 配置Git
当安装 Git 后首先要做的事情是设置你的 用户名称 和 e-mail 地址,这是非常重要的。配置命令为:
bash
git config [--global] user.name "Your Name"
git config [--global] user.email "email@example.com"
# 把 Your Name 改成你的昵称
# 把 email@example.com 改成邮箱的格式,只要格式正确即可。
3. 认识工作区、暂存区、版本库
- 工作区:是在电脑上你要写代码或文件的目录。
- 暂存区:英文叫 stage 或 index。一般存放在 .git 目录下的 index 文件(.git/index)中,我们把暂存区有时也叫作索引(index)。
- 版本库:又名仓库,英文名 repository 。工作区有一个隐藏目录 .git ,它不算工作区,而是 Git 的版本库。这个版本库里面的所有文件都可以被 Git 管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以"还原"。
下面这个图展示了工作区、暂存区和版本库之间的关系:
• 图中左侧为工作区,右侧为版本库。Git 的版本库里存了很多东西,其中最重要的就是暂存区。
• 在创建 Git 版本库时,Git 会为我们自动创建一个唯一的 master 分支,以及指向 master 的一个指针叫 HEAD。(分支和HEAD的概念后面再说)
• 当对工作区修改(或新增)的文件执行 git add 命令时,暂存区目录树的文件索引会被更新。
• 当执行提交操作git commit 时,master 分支会做相应的更新,可以简单理解为暂存区的目录
树才会被真正写到版本库中。
4. 版本回退
执行 git reset
命令用于回退版本,可以指定退回某一次提交的版本。要解释一下"回退"本质是要将版本库中的内容进行回退,工作区或暂存区是否回退由命令参数决定:
git reset
命令语法格式为:
bash
git reset [--soft | --mixed | --hard] [HEAD]
• --mixed 为默认选项,使用时可以不用带该参数。该参数将暂存区的内容退回为指定提交版本内
容,工作区文件保持不变。
• --soft 参数对于工作区和暂存区的内容都不变,只是将版本库回退到某个指定版本。
• --hard 参数将暂存区与工作区都退回到指定版本。切记工作区有未提交的代码时不要用这个命
令,因为工作区会回滚,你没有提交的代码就再也找不回了,所以使用该参数前一定要慎重。
• HEAD 说明:
◦ 可直接写成 commit id,表示指定退回的版本
◦ HEAD 表示当前版本
◦ HEAD^ 上一个版本
◦ HEAD^^ 上上一个版本
◦ 以此类推...
• 可以使用 ~数字表示:
◦ HEAD~0 表示当前版本
◦ HEAD~1 上一个版本
◦ HEAD^2 上上一个版本
◦ 以此类推...
为了便于表述,方便测试回退功能,我们先做一些准备工作:更新3个版本的 ReadMe,并分别进行3次提交,如下所示:
5. 撤销修改
情况1:对于工作区的代码,还没有add
-
直接删除代码
-
使用:
bashgit checkout -- [filename]
情况二:已经add ,但没有commit
git reset 回退命令,该命令如果使用 --mixed 参数,可以将暂存区
的内容退回为指定的版本内容,但工作区文件保持不变。
bash
git reset --mixed HEAD ReadMe
这样以后就变成了情况一了,可以继续使用 git checkout --
来丢弃工作区的修改。
情况三:已经add ,并且也commit 了
前提:还没有push到远端仓库
我们可以 git reset --hard HEAD^
回退到上一个版本。不过,这是有条件的,就是
你还没有把自己的本地版本库推送到远程。
删除文件
bash
rm
rm命令只会删除工作区的文件,对于暂存区和版本库中的内容没有影响。
一般删除文件,有两种可能:
• 确实要从版本库中删除该文件
• 不小心删错了 - git checkout -- filename
恢复工作区文件
对于第一种情况,很明显是没有删完,我们只删除了工作区的文件。这时就需要使用 git rm
将文
件从暂存区和工作区中删除,并且 commit 。