首页 > 代码库 > 1-git初体验

1-git初体验

1 准备工作: windows系统下,安装好msysgit  -安装好后,在开始菜单找到Git  > Git bash

2 当前电脑配置用户名 邮箱

$ git config --global user.name "Your Name"$ git config --global user.email "email@example.com"

因为Git是分布式版本控制系统,所以,每个机器都必须自报家门:你的名字和Email地址。你也许会担心,如果有人故意冒充别人怎么办?这个不必担心,首先我们相信大家都是善良无知的群众,其次,真的有冒充的也是有办法可查的。

注意git config命令的--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址。

如果你希望在一个特定的项目中使用不同的名称或e-mail地址,你可以在该项目中运行该命令而不要--global选项

如果已经设置过可以通过 git config --list 查看

技术分享

3 进入主题开始使用 (先在桌面上创建一个 文件夹:secondgit ;或使用自己的项目文件夹)

4 在secondgit右键 Git Bash Here

技术分享

这时我们 创建一个usegit.html 文件,随便加点内容

技术分享

5 把当前目录(secondgit)作为git的版本库(仓库)responsitory

  可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。

 (如果你使用Windows系统,为了避免遇到各种莫名其妙的问题,请确保目录名(包括父目录)不包含中文。) pwd命令用于显示当前目录 技术分享

  通过git init命令把这个目录变成Git可以管理的仓库

技术分享 

发现当前目录下多了一个.git的目录,这个目录是Git来跟踪管理版本库的,没事千万不要手动修改这个目录里面的文件,不然改乱了,就把Git仓库给破坏了。

如果你没有看到.git目录,那是因为这个目录默认是隐藏的,用ls -ah命令就可以看见。

6 第一次提交 把一个文件放到Git仓库只需要两步。

 6.1   第一步,用命令git add告诉Git,把文件添加到仓库:

技术分享

 6.2 第二步,用命令git commit告诉Git,把文件提交到仓库:

      这时我们先看看 git的状态技术分享

     开始提交

技术分享

   这时再看看 git的状态 技术分享

 

7 第二次提交 这时我们改动 usegit.html 技术分享

 看看此时 git的状态技术分享 提示修改过了

 看看改动了什么技术分享

 再次add 和 commit

技术分享

看看git的状态 技术分享

8 第三次修改技术分享

 

并提交

技术分享

9 使用git的 版(时) 本(光) 回(机) 退功能

9.1 q:我们总共做了几次修改呢? a: 三次

查看所做的修改技术分享 

嫌输出信息太多,看得眼花缭乱的,我不会告诉你还可以加参数o(╯□╰)o --pretty=oneline参数技术分享

9.2 假设boss说你内容区域做的太lower了,重做!于是想回到 第二次提交后的状态

首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交85e0890...bbe65d0(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^

当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100

现在,我们要把当前版本 “添加了底部” 回退到上一个版本“添加了内容区域”,就可以使用git reset命令:

技术分享

发现我们已经回到了上个版本技术分享

再 git log一下看看提交的情况 技术分享

最新的那个版本 “添加了底部” 已经看不到了!好比你从21世纪坐时光穿梭机来到了19世纪,想再回去已经回不去了,肿么办?

办法其实还是有的,只要上面的命令行窗口还没有被关掉,你就可以顺着往上找啊找啊,找到那个 “添加了底部” 的commit id是85e0890...,于是就可以指定回到未来的某个版本:

 技术分享

查看usegit.html文件 技术分享 嗯...我又回来了

技术分享变化是这样的,图片是借用廖雪峰大神的--千万不要钻牛角尖

 

9.3 现在,你回退到了某个版本,关掉了电脑,第二天早上就后悔了,想恢复到新版本怎么办?找不到新版本的commit id怎么办?

  在Git中,总是有后悔药可以吃的。当你用$ git reset --hard HEAD^回退到add distributed版本时,再想恢复到 "添加了底部" ,就必须找到 “添加了底部” 的commit id。

  Git提供了一个命令git reflog用来记录你的每一次命令:

技术分享

 

1-git初体验