zoukankan      html  css  js  c++  java
  • Git学习笔记--版本控制

    版本控制

    我们试着提交一个readme.txt文件,并用其感受版本控制功能。

    原readme文件内容:

    this is cp's channel.
    nice to meet u.

    使用add,commit提交到仓库。

    然后修改第二行的u->you保存。

    this is cp's channel.
    nice to meet you.

    这时我们可以通过命令:git status 查看库的当前状态。

    $ git status
    On branch master
    Changes not staged for commit:
      (use "git add <file>..." to update what will be committed)
      (use "git restore <file>..." to discard changes in working directory)
            modified:   readme.txt
    
    no changes added to commit (use "git add" and/or "git commit -a")

    会告诉我们readme已经被修改。

    我们可以使用命令:git diff filename 查看具体的更改内容。

    $ git diff readme.txt
    diff --git a/readme.txt b/readme.txt
    index 962cb11..fb5ee03 100644
    --- a/readme.txt
    +++ b/readme.txt
    @@ -1,2 +1,2 @@
     this is cp's channel.
    -nice to meet u.
     No newline at end of file
    +nice to meet you.
     No newline at end of file

    然后我们再add、commit修改后的版本。

    此时再查看status就显示

    nothing to commit, working tree clean

    没东西要commit,工作目录是干净的。

    版本回退

    此时我们已经提交了两次readme,怎么回退到上一个版本呢?

    首先我们看看git log命令,可以查看所有的历史版本,也就是你每commit一次就会有一个新的版本。

    git log命令会给出版本号、作者、提交时间和说明。

    使用git reset命令可以进行回滚,命令格式:

    $ git reset --hard HEAD^

    HAED表示当前版本,HEAD^就是上一个版本,同理HEAD^^就是上上个版本,HEAD~n就是前n个版本。此处也可以用版本号来代替(不用写全,前几位就行,Git会自动匹配)。

    查看文件果然被回滚了。

    回到过去可以,但是想重返未来呢?只要找到版本号就可以去到任意地方,如果已经回退了,可以用git reflog查看命令历史,里边可以看到你对任何一个版本的操作,包括版本号。

    Git里面怎么操作的?--工作区和暂存区

    Git可以分为两个区域,工作区和暂存区。

    工作区就是你仓库目录,不包括.git目录。

    .git目录下就是版本库,版本库里有暂存区和分支(也就是你的仓库)。master分支是自动创建的。

    暂存区一直保存上一次add的内容。

    git add 实际上是将工作区文件添加到暂存区,

    git commit 是将暂存区文件添加到分支,

    git diff 是查看工作区和暂存区差别,

    git diff --cached 是查看暂存区和分支区别,

    git diff HEAD 是查看工作区和分支区别,

    git checkout 是撤销工作区修改,把暂存区最新版本转到工作区,是add反向命令,

    git reset HEAD 是把仓库最新版本转到暂存区。

    Git管理的是修改不是文件

    每次add就是将一次修改提交到暂存区。

    这个需要使用时慢慢理解。

    撤销修改

    git checkout -- filename 命令,就是将暂存区最新版本转到工作区

    git reset HEAD filename 是把仓库最新版本转到暂存区

    如果修改了工作区文件,没有add,用checkout;

    如果add了,用reset HEAD,此时暂存区回退,再用checkout,工作区回退;

    如果你还脑子短路commit了,用reset -hard HEAD^,将暂存区、工作区都回滚到上一次提交,仅add没commit也可用此法。

    删除文件

    git rm filename,删除文件。并且git commit提交修改。

    参考:廖雪峰的Git教程

  • 相关阅读:
    Android对包名和类名是否存在的判断
    Android权限表
    论艺术的背后还有纪律
    jeecgboot/IDEA中 debug不行,run可以
    java集合类
    HashMap、HashTable、LinkedHashMap和TreeMap用法和区别
    protobuf序列化算法原理
    谁能帮我看看着究竟是什么问题呀,我在本机运行都是好好的,但在别人的机子上运行就出这个呢?我快疯了!!!
    VS删除空白行
    POJ 2516 Minimum Cost
  • 原文地址:https://www.cnblogs.com/cpcpp/p/12952570.html
Copyright © 2011-2022 走看看