Git

首先,选择一个合适的地方,创建一个空目录
$ mkdir learngit
$ cd learngit
$ pwd
/c/Users/QWJ/learngit
第二步,通过git init命令把这个目录变成Git可以管理的仓库:
$ git init
Reinitialized existing Git repository in C:/Users/QWJ/.git/

使用Notepad++创建一个为readme.txt的文件

  • 把文件提交到仓库

    1. 用命令git add告诉Git,把文件添加到仓库:
      $ git add readme.txt
      
      没有任何显示的时候说明添加成功
    2. 用命令git commit告诉Git,把文件提交到仓库:
       $ git commit -m "wrote a new file"
      [master (root-commit) eaadf4e] wrote a new file
      1 file changed, 1 insertions(+)
       create mode 100644 new.txt
      

    -m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。

    1 file changed:1个文件被改动(我们新添加的readme.txt文件);
    1 insertions:插入了一行内容(readme.txt有一行内容)。

git add < file>,可反复多次使用,添加多个文件。
git commit -m< message>,可一次提交很多文件。
  • 修改readme.txt,再运行git status命令查看结果
Changes not staged for commit:
	(use "git add/rm <file>..." to update what will be committed)
	(use "git checkout -- <file>..." to discard changes in working directory)

        modified:   readme.txt
        deleted:    ../readme.txt
        
no changes added to commit (use "git add" and/or "git commit -a")

git status命令可以让我们时刻掌握仓库当前的状态,上面的命令输出告诉我们,
readme.txt被修改过了,但还没有准备提交的修改。

git diff,可以用来看具体修改了什么内容
在这里插入图片描述
可以看出来增加了一行信息‘add a new line’

执行git add后再进行git status查看

On branch master
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

        modified:   readme.txt

git status告诉我们,将要被提交的修改包括readme.txt,下一步,就可以放心地提交了:
在这里插入图片描述

要随时掌握工作区的状态,使用git status命令。
如果git status告诉你有文件被修改过,用git diff可以查看修改内容。
  • 版本控制系统肯定有某个命令可以告诉我们历史记录,在Git中,我们用git log命令查看:
$ git log
commit faf931710e72115ce85340473b83024b24bc7f85 (HEAD -> master)
Author: qiwenjin <2242028620@qq.com>
Date:   Sun May 5 15:33:27 2019 +0800

    add a line

commit ff3fc0121fee6f25f174d545b4a1fc6f2da58e00
Author: qiwenjin <2242028620@qq.com>
Date:   Sun May 5 15:14:08 2019 +0800

    x

commit 197253533bfa1363448f25dffc97f2249dd09797
Author: qiwenjin <2242028620@qq.com>
Date:   Sun May 5 15:12:05 2019 +0800

    wrote a readme file

git log 命令显示从最近到最远的提交日志,我们可以看到3次提交,最近的一次是add a line,上一次是x,最早的一次是wrote a readme file。

如果嫌输出信息太多,看得眼花缭乱的,可以试试加上–pretty=oneline参数:

$ git log --pretty=oneline
faf931710e72115ce85340473b83024b24bc7f85 (HEAD -> master) add a line
ff3fc0121fee6f25f174d545b4a1fc6f2da58e00 x
197253533bfa1363448f25dffc97f2249dd09797 wrote a readme file

你看到的一大串类似faf93…的是commit id(版本号)

  • 找回之前版本
    Git中,用HEAD表示当前版本,也就是最新的提交faf93…,上一个版本就是HEAD ^ ,上上一个版本就是HEAD^ ^ ,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。

现在,我们要把当前版本add a line回退到上一个版本x,就可以使用git reset命令:

$ git reset --hard HEAD^
HEAD is now at ff3fc01 x

看看readme.txt的内容是不是版本x:

$ cat readme.txt
a new thing

只要上面的命令行窗口还没有被关掉,你就可以顺着往上找啊找啊,找到那个add a line的commit id是faf93…,于是就可以指定回到未来的某个版本:

$ git reset --hard faf93
HEAD is now at faf9317 add a line

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

$ git reflog
faf9317 (HEAD -> master) HEAD@{0}: reset: moving to faf93
faf9317 (HEAD -> master) HEAD@{1}: reset: moving to faf93
ff3fc01 HEAD@{2}: reset: moving to HEAD^
faf9317 (HEAD -> master) HEAD@{3}: commit: add a line
ff3fc01 HEAD@{4}: commit: x
1972535 HEAD@{5}: commit (initial): wrote a readme file

从输出可知,append GPL的commit id是faf93…

HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id。
穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。
  • 工作区和暂停区
    1. 工作区(Working Directory):就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区:

    2. 版本库(Repository):工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
      Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。
      在这里插入图片描述
      前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:

      第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;
      第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。

      因为我们创建Git版本库时,Git自动为我们创建了唯一一个master分支,所以,git commit就是往master分支上提交更改。
      git add命令实际上就是把要提交的所有修改放到暂存区(Stage),然后,执行git commit就可以一次性把暂存区的所有修改提交到分支。
      一旦提交后,如果你又没有对工作区做任何修改,那么工作区就是“干净”的:

  • 管理修改
    第一次修改 -> git add -> 第二次修改 -> git commit
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

        modified:   readme.txt
        
no changes added to commit (use "git add" and/or "git commit -a")

第二次的修改没有被提交

提交后,用git diff HEAD – readme.txt命令可以查看工作区和版本库里面最新版本的区别:

$ git diff
index 3987f5e..6f9367d 100644
--- a/learngit/readme.txt
+++ b/learngit/readme.txt
@@ -1,2 +1,3 @@
 a new thing
-add a new word
\ No newline at end of file
+add a new word
+the third line
\ No newline at end of file
每次修改,如果不用git add到暂存区,那就不会加入到commit中。
  • 撤销修改
  1. 在git add前发现错误$ git checkout -- readme.txt
    命令git checkout – readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销
    1. readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
    2. readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
  2. git add之后,git commit之前
    用命令git reset HEAD < file >可以把暂存区的修改撤销掉
    git reset命令既可以回退版本,也可以把暂存区的修改回退到工作区。当我们用HEAD时,表示最新的版本。
场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout – file。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD < file>,就回到了场景1,第二步按场景1操作。
场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,git reset --hard commit_id,不过前提是没有推送到远程库。
  • 删除文件
    1. 在文件管理器中把没用的文件删了,或者用rm命令删了:
      $ rm test.txt
      使用git status查看哪些文件被删除了
    On branch master
    Changes not staged for commit:
     (use "git add/rm <file>..." to update what will be committed)
     (use "git checkout -- <file>..." to discard changes in working directory)
    
         deleted:    test.txt
    no changes added to commit (use "git add" and/or "git commit -a")
    
    1. 从版本库中删除该文件,那就用命令git rm删掉,并且git commit:
    $ git rm test.txt
    rm 'learngit/test.txt'
    
    $ git commit -m"remove test.txt"
    [master 1bee058] remove test.txt
    1 file changed, 1 deletion(-)
     delete mode 100644 learngit/test.txt
    

如果删错了,因为版本库里还有呢,所以可以很轻松地把误删的文件恢复到最新版本:
$ git checkout -- test.txt
git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。

命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值