每个开发人员应该都会一个版本管理工具,在Git和SVN中,我选择以Git,以下是我的一些心得

什么是 Git

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

一、Git安装

1)、linux下安装:

Ubuntu Linux,通过一条sudo apt-get install git就可以直接完成Git的安装,非常简单。

2)、windows下安装:

Git官网 下载,然后全部选默认,一直点next就可以

2.首次使用的一些设置

1)、设置用户名和邮箱,用来区分用户(注:在windows中,安装完成后在开始菜单中有个Git Bash,点击这个就可以打开Git,里边是写Git的命令的)

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

2)、创建版本库

创建一个版本库非常简单,首先,选择一个合适的地方,创建一个空目录:

  1. $ mkdir learngit
  2. $ cd learngit
  3. $ pwd
  4. D:/JavaWorkSoftware/git/learngit

注:最后这个pwd是用来查看当前目录,如果你使用Windows系统,请确保目录名(包括父目录)不包含中文。

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

  1. $ git init
  2. Initialized empty Git repository in D:/JavaWorkSoftware/git/learngit/.git/

好了,你的Git就算是安装完成了。然后就开始使用吧。

4)、我们写一个文件到仓库中

创建一个example.txt

  1. This is an example file,
  2. This is creat in Git.

(2).添加文件进去,用git add命令

  1. $ git add example.txt
  2. warning: LF will be replaced by CRLF in example.txt.
  3. The file will have its original line endings in your working directory

这个命令一般是不会有任何提示的,但是我出现了如上提示。

意思大概是:LF(换行,Line Feed)将会被CRLF(回车换行,CarriageReturn)替代

该文件将在工作目录中具有其原始行尾。

报这个警告时是由于文件夹远程不存在,但是不影响提交。我们再执行一次就好。

(3).提交git commit

  1. $ git commit -m "first example file"
  2. [master (root-commit) 0cecffa] first example file
  3. 1 file changed, 2 insertions(+)
  4. create mode 100644 example.txt

这个commit命令的参数 -m 是必不可少的,就是为了添加本次提交文件的日志,相当于做一个标记,以便于我们在版本控制时用到。

  1. tips:在git中只有存纯文本文件,如.txt .java .md 不能存其他文件,同时,这些纯文本文件要是UTF-8编码

二、版本控制

以本地仓库为例,讲解版本控制

1)、我们先讲几个概念

工作区和暂存区

工作区(Working Directory),就是是在我们电脑上能看到的文件目录,这里我的那个/learngit就是一个工作区,在工作区中有很多的分支。

分支(Branching),顾名思义,就是类似于树叶的分支。我们将整个工作区比作主树干,分支的概念就更好地理解了。我们现在就是在Git的主分支(master)上操作,后边会讲到分支管理。

我们之前用mkdir learngit 命令创建的那个就是一个工作区,在工作区中有一个隐藏目录.git,这个就是Git的版本库(Repository)

暂存区,就是我们当前正在操作的目录,但是内容还没有保存在工作区中

2)、Git下修改文件

我们把在Git下操作文件和如何把大象装进冰箱中做类比(这是我本人很喜欢的一个学习方法):

(1).我们修改当前工作区下的 example.txt 文件 (准备大象,肯定有人会问,不用准备冰箱吗?哈哈,Git就是这个冰箱了).

  1. This is an example file,
  2. This is creat in Git.
  3. This is third line.

(2).每二步肯定就是将大象装进冰箱,我们用git add命令

但在把大象装进冰箱前,我们先学习几个小命令

git status 查看当前git 的状态

  1. $git status
  2. On branch master
  3. Changes not staged for commit:
  4. (use "git add <file>..." to update what will be committed)
  5. (use "git checkout -- <file>..." to discard changes in working directory)
  6. modified: example.txt
  7. no changes added to commit (use "git add" and/or "git commit -a")

修改了example.txt 文件

已经修改,但是这个修改没有提交到时工作区,提示你用git add 或git commit

另一个命令就是 git diff用来查看修改前后两个文件的不同,这个就不做演示了。

还有一个git checkout -- [文件名] ,撤销修改,也就是说这个时候我们突然不想把大象装进冰箱了,我们只需要撤销就好了。

  1. $git checkout -- example.txt

这个命令执行完毕后不会有任何提示。 我们接着用git status 查看下我们的git状态,就是说我们的这个git没有任何要commit的文件

  1. $ git status
  2. On branch master
  3. nothing to commit, working tree clean

(3).好了,学完这几个小插曲后,我们继续我们的大象装进冰箱(修改库中文件)的最后一步,就是关闭冰箱门(git commit -m)。

我们刚刚执行了撤销修改的操作,我们要重新来一次。

  1. This is an example file,
  2. This is creat in Git.
  3. This is third line.

$git add example.txt

$git commit -m "add third line"

3)、版本更换:真正的在多个版本之前切换

为了文件测试,我们多修改几次这个文件,也就是多做几个版本(此操作略,无非就是vim——add——commit)。

在你修改了好几个版本之后,我们用git log命令来查看当前工作区(其实就是分支)状态.

  1. $ git log
  2. commit 7b0b4f5c4c9ffc053db65ed0d7835ae62a27e0b6 (HEAD -> master)
  3. Author: Lyn4ever <Lyn4ever29@163.com>
  4. Date: Fri Jun 7 00:23:54 2019 +0800
  5. add fourth line
  6. commit 11b13721088ea653042af7986e0d5b1f1b29a9e9
  7. Author: Lyn4ever <Lyn4ever29@163.com>
  8. Date: Fri Jun 7 00:16:12 2019 +0800
  9. add third line
  10. commit 0cecffad8b547533728d2c1a9bef581c6c01f359
  11. Author: Lyn4ever <Lyn4ever29@163.com>
  12. Date: Thu Jun 6 23:45:24 2019 +0800
  13. first example file

这个很容易看明白的,就是现在有三个版本,这是一个倒序排序,也就是说,当前这个文件的版本就是最上边的这个。commit 后边跟着的那个就是版本号,紧接着两行是作者和时间,再下边就是我们在commit -m 时写的日志了。(注意:你的文件id 肯定和我的不一样,在测试时要以你的为准)

修改版本的命令是git reset --hard commit_id,我们就来试一试。

先确保当前git中没有未commit的文件,然后查看文件内容

  1. $ git status
  2. On branch master
  3. nothing to commit, working tree clean
  1. $ cat example.txt
  2. This is an example file,
  3. This is creat in Git.
  4. this is third line.
  5. this is forth line.

好了,我们就返回日志为"add third line"这个版本,其版本id为:11b13721088ea653042af7986e0d5b1f1b29a9e9

  1. $git reset --hard 11b13721088ea653042af7986e0d5b1f1b29a9e9
  2. HEAD is now at 11b1372 add third line

看提示,很明显,就是经成功了。我们再看一个

  1. $ git status
  2. On branch master
  3. nothing to commit, working tree clean
  1. $ cat example.txt
  2. This is an example file,
  3. This is creat in Git.
  4. this is third line.

每次要写这个id是不是很麻烦呢,我们可以只用前7个字符,但是还有一个更简单的方法,就是用HEAD^来代替。HEAD 表示当前版本,往前几个版本,就写几个^。上一个版本就是HEAD^,上上一个就是HEAD^^

这时,我们再看一个我们的git log

  1. $ git log
  2. commit 11b13721088ea653042af7986e0d5b1f1b29a9e9 (HEAD -> master)
  3. Author: Lyn4ever <Lyn4ever29@163.com>
  4. Date: Fri Jun 7 00:16:12 2019 +0800
  5. add third line
  6. commit 0cecffad8b547533728d2c1a9bef581c6c01f359
  7. Author: Lyn4ever <Lyn4ever29@163.com>
  8. Date: Thu Jun 6 23:45:24 2019 +0800
  9. first example file

发现这个里边只有两个了,我想回到add fourth line 那个版本,也是用同样的方法,但是我找不到commit-id 怎么办?不急,git这么强大的功能不会让我们失望的。我们可以用git reflog查看git版本控制的操作历史

  1. $ git reflog
  2. 11b1372 (HEAD -> master) HEAD@{0}: reset: moving to 11b13721088ea653042af7986e0d5b1f1b29a9e9
  3. 7b0b4f5 HEAD@{1}: commit: add fourth line
  4. 11b1372 (HEAD -> master) HEAD@{2}: commit: add third line
  5. 0cecffa HEAD@{3}: commit (initial): first example file

这时,我们找到了之前add fourth line 版本的id,就可以了。

  1. $git reset --hard 7b0b4f5

就这样好了。git log 又发现了三个版本

  1. $ git log
  2. commit 7b0b4f5c4c9ffc053db65ed0d7835ae62a27e0b6 (HEAD -> master)
  3. Author: Lyn4ever <Lyn4ever29@163.com>
  4. Date: Fri Jun 7 00:23:54 2019 +0800
  5. add fourth line
  6. commit 11b13721088ea653042af7986e0d5b1f1b29a9e9
  7. Author: Lyn4ever <Lyn4ever29@163.com>
  8. Date: Fri Jun 7 00:16:12 2019 +0800
  9. add third line
  10. commit 0cecffad8b547533728d2c1a9bef581c6c01f359
  11. Author: Lyn4ever <Lyn4ever29@163.com>
  12. Date: Thu Jun 6 23:45:24 2019 +0800
  13. first example file

4)、删除文件

删除文件,其实就是另一种修改操作,和修改是一样的,先用rm file来删除,然后用git commit来提交到工作空间中。

  1. $rm example.txt

然后我我们看一下状态

  1. $ git status
  2. On branch master
  3. Changes not staged for commit:
  4. (use "git add/rm <file>..." to update what will be committed)
  5. (use "git checkout -- <file>..." to discard changes in working directory)
  6. deleted: example.txt
  7. no changes added to commit (use "git add" and/or "git commit -a")

发现是deleted ,但是没有commit。也就是已经把大象从冰箱中取出来了,但是没有关冰箱门。所以我们关闭冰箱门

先从库中删除

  1. $ git rm example.txt
  2. rm 'example.txt'

然后提交

  1. git commit -m "delete example"

然后,想查看这个文件,发现不在了。

  1. $ cat example.txt
  2. cat: example.txt: No such file or directory

最后,我们用之前的版本回退回去。

  1. $ git reset --hard 7b0b4f5
  2. HEAD is now at 7b0b4f5 add fourth line
  3. $ cat example.txt
  4. This is an example file,
  5. This is creat in Git.
  6. this is third line.
  7. this is forth line.

tips: 删除文件同样也是修改操作,也可以在rm file后,但还没有git rmgit commit到git库中前,可以使用git checkout -- fileaname 撤销

新手学习Git之在本地使用Git的更多相关文章

  1. 使用git 将自己的本地文件git到github上面的完整过程

    1.  首先在github网站上新建一个仓库,复制仓库地址(HTTP形式或者SSH形式,后者利用SSH,在最后一步push 的时候可以不用输入用户名和密码). 2.  在本地某个你想要的(文件夹)目录 ...

  2. git操作之四:git branch(本地仓库)

    前面,介绍了git init/add/commit/restore/reset等git命令,今天介绍下git branch,这个命令是和分支相关的.首先要理解什么是分支,简单来说在协作开发中,每个人开 ...

  3. Git(2) - git安装、本地仓库与远程仓库使用详细指南

    git版本控制工具 下载地址:https://www.git-scm.com/download/win选择对应版本的工具,下载后是一个exe执行文件: 常用git命令 命令 作用 git init(在 ...

  4. Git版本管理:Windows下Git配置与使用指南

    简要介绍:Git是一个开源的分布式版本控制系统,用以有效.高速的处理从很小到非常大的项目版本管理. 一.安装 软件:msysGit-fullinstall-1.8.1.2 打开之后设置安装路径,默认为 ...

  5. Git版本管理:Windows下Git配置与使用指南 Gitlab

    简要介绍:Git是一个开源的分布式版本控制系统,用以有效.高速的处理从很小到非常大的项目版本管理. 一.安装 软件:msysGit-fullinstall-1.8.1.2 打开之后设置安装路径,默认为 ...

  6. 有关git的使用,和git的一些提交冲突。

    git 的一些基本用法 git init :初始化文件(创建文件夹). git add . :监控工作区的状态树(将被修改的文件提交到暂存区) git status :未跟踪状态(Untracked) ...

  7. git 学习使用总结一(本地操作)

    通过几天的学习,熟悉了 git 的一些常用命令,要用熟练和操作更复杂的功能还必须继续学习.不过 git 作为工具,它是用来提高我们的工作效率的工具,系统的学习之后可以暂且放放,等到以后实际项目中用到了 ...

  8. Git 学习(三)本地仓库操作——git add & commit

    Git 学习(三)本地仓库操作——git add & commit Git 和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念.这在上文已有提及,本文具体说明什么是工作区及暂存区,以及 ...

  9. Git学习(2)-使用Git 代码将本地文件提交到 GitHub

    上次随笔写到git的安装和运用命令窗口创建本地版本库,这次主要讲一下用git代码将本地文件提交到GitHub上. 前提是有一个GitHub账号. 1.创建一个新的版本库,进入到你本地项目的根目录下(我 ...

随机推荐

  1. Linux应用开发自学之路

    前言 在 「关于我 」那篇博文里,朋友们应该知道了我不是科班出身,是由机械强行转行到Linux应用开发方向.下面我就详细向大家介绍自己这一路上的转行历程,希望对大家有所启发. 我是学机械专业的,对于机 ...

  2. ASP.NET Core 2.2 : 二十六. 应用JWT进行用户认证

    本文将通过实际的例子来演示如何在ASP.NET Core中应用JWT进行用户认证以及Token的刷新方案(ASP.NET Core 系列目录) 一.什么是JWT? JWT(json web token ...

  3. MSIL实用指南-数据类型转换

    一.类的强制转换1.转换成某个类用Castclass指令.实例代码:ilGenerator.Emit( OpCodes.Castclass , typeof(ClassA) ); 2.转换成某个值类型 ...

  4. 借助 RAM disk 技术,加快前端工程打包速度

    背景以 Jenkins 服务器为例,在构建内部的这个项目时,CE 每部署一次服务,最快 6 分钟,最慢将近 13 分钟左右.遇到多个项目并发打包会因为资源占用等问题时间会延长,甚至出现过几次 20 分 ...

  5. Badboy - 导出脚本,用于JMeter并发测试

    参考: http://leafwf.blog.51cto.com/872759/1141011 http://www.51testing.com/html/00/130600-1367743.html ...

  6. 2019dx#4

    Solved Pro.ID Title Ratio(Accepted / Submitted)   1001 AND Minimum Spanning Tree 31.75%(1018/3206)   ...

  7. 最短路算法 Dijkstra 入门

    dijkstra算法 是一种单源点最短路算法求出一个点到其他所有点的最短路. 给你这样的一个图,需要求出1号点到其他点的最短距离是多少. 首先我们开一个数组 d[N],d[x] 代表着从起点出发到x点 ...

  8. POJ 3070 Fibonacci 矩阵快速幂模板

    Fibonacci Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 18607   Accepted: 12920 Descr ...

  9. Spring.Net是怎么在MVC中实现注入的(原理)

    本文将介绍Spring.Net(不仅仅是Spring.Net,其实所有的IoC容器要向控制器中进行注入,原理都是差不多的)在MVC控制器中依赖注入的实现原理,本文并没有关于在MVC使用Spring怎么 ...

  10. 【2】KNN:约会对象分类器

    前言 这是一个KNN算法的应用实例,参考<机器学习实战>中的datingTestSet2.txt的数据集. 可以通过对不同约会对象的特征进行分析然后自动得出以下三种结论: 不喜欢的 有点魅 ...