• 2 修改与恢复


    将readme.txt添加到仓库后,现在来修改它:

    Git is a distributed version control system.
    GIt is free software.

    运行git status 或加上文件名:

    位于分支 master
    尚未暂存以备提交的变更:
      (使用 "git add <文件>..." 更新要提交的内容)
      (使用 "git checkout -- <文件>..." 丢弃工作区的改动)
    
        修改:     readme.txt
    
    修改尚未加入提交(使用 "git add" 和/或 "git commit -a"

    运行git diff或加上文件名:

    查看变更内容

    diff --git a/practice/readme.txt b/practice/readme.txt
    index f1dc24f..a431595 100644
    --- a/practice/readme.txt
    +++ b/practice/readme.txt
    @@ -1,2 +1,3 @@
    -Git is a version control system.                    
    +Git is a distributed version control system.           #添加了distributed
     GIt is free software.

    与提交新文件一样,提交修改也是两步:

    $ git add readme.txt                               #第一步,添加,无异常,提交前先查看下状态
    $ git status
    位于分支 master
    要提交的变更:
      (使用 "git reset HEAD <文件>..." 以取消暂存)
    
        修改:     readme.txt
    
    $ git commit -m 'add distributed'                   #第二步,提交,正常,再看下状态
    [master ab16d2b] add distributed
     1 file changed, 2 insertions(+), 1 deletion(-)
    $ git status
    位于分支 master
    无文件要提交,干净的工作区                              #ok

    小结:

    查看工作区状态用 git  status,git diff查看修改内容

    版本回退:

    查看提交历史记录,由近及远:

    l@ubuntu:~/learngit$ git log
    commit abd8c7d5ed726202b600fa5c312ddcd111522830
    Author: gitstudy <327599582@qq.com>
    Date:   Fri Nov 10 22:28:28 2017 +0800
    
        append GPL
    
    commit ab16d2b4bad7096b504266b8937390cd7f7ecf3c
    Author: gitstudy <327599582@qq.com>
    Date:   Thu Nov 9 22:51:34 2017 +0800
    
        add distributed
    
    commit a6d66840e42757136a5976275c02386d849302c5           #版本号:SHA1算法 十六进制
    Author: gitstudy <327599582@qq.com>
    Date:   Tue Nov 7 23:38:38 2017 +0800
    
        wrote a readme file
    l@ubuntu:~/learngit$ git log --pretty=oneline             #简单显示
    abd8c7d5ed726202b600fa5c312ddcd111522830 append GPL
    ab16d2b4bad7096b504266b8937390cd7f7ecf3c add distributed
    a6d66840e42757136a5976275c02386d849302c5 wrote a readme file

    在Git中,当前版本:HEAD,上一版本:HEAD^,上上版本:HEAD^^,...,HEAD~n。回退至上一版本,用git reset

    l@ubuntu:~/learngit$ git reset --hard HEAD^
    HEAD 现在位于 ab16d2b add distributed
    l@ubuntu:~/learngit/practice$ cat readme.txt 
    Git is a distributed version control system.      #已经回退
    GIt is free software.

     再次回退前查看log

    l@ubuntu:~/learngit$ git log --pretty=oneline        #append GPL版本没了
    ab16d2b4bad7096b504266b8937390cd7f7ecf3c add distributed
    a6d66840e42757136a5976275c02386d849302c5 wrote a readme file

    要回退至append GPL必须找到其commit id,通过git reflog查看:

    l@ubuntu:~/learngit$ git reflog 
    ab16d2b HEAD@{0}: reset: moving to HEAD^
    abd8c7d HEAD@{1}: commit: append GPL
    ab16d2b HEAD@{2}: commit: add distributed
    a6d6684 HEAD@{3}: commit (initial): wrote a readme file
    l@ubuntu:~/learngit/practice$ git reset --hard abd8c7d
    HEAD 现在位于 abd8c7d append GPL
    l@ubuntu:~/learngit/practice$ cat readme.txt       #回到append GPL版本
    Git is a distributed version control system.
    GIt is free software distributed under the GPL.

    总结:

      HEAD指当前版本,使用git reset  --hard  commit_id回退至某个版本

      回退前用git log查看提交历史,确定回退的版本

      用git reflog查看命令历史

    工作区和暂存区

    工作区(working directory):如learngit目录

    版本库(repository):工作区的隐藏目录 .git不算工作区,而是Git版本库

    版本库中最重要的是stage(或index)即暂存区,还有Git给我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD

    1、git add命令把文件修改添加到暂存区

    2、git commit命令把暂存区的所有内容提交到当前分支即master分支,注:提交是把暂存区的所有修改一次性提交完

    管理修改

    Git跟踪是修改而非文件,修改都是在工作区,add的次数要大于等于修改的次数,可全部添加后统一git commit

    撤销修改

    1、工作区修改后还没有 add 到暂存区:手动更正

                      git checkout  --  readme.txt 把在工作区的修改全部撤销

    2、工作区修改后add到暂存区:分两步1:git reset HEAD readme.txt将暂存区修改回退至工作区,HEAD是最新版本

                      2:git checkout  --  readme.txt

    3、已经提交了不合适的修改到版本库:在没有推送到远程库的前提下,通过版本回退撤销本次提交,然后重复2的操作

    删除文件

    在Git中,删除也是一个修改动作,例:

    先在工作区创建一个文件,添加并提交

    $ touch test.txt      #使用了sh 命令
    $ ls
    license  readme.txt  test.txt
    $ git add test.txt
    $ git commit -m 'add test.txt'
    [master 818fddc] add test.txt
     1 file changed, 0 insertions(+), 0 deletions(-)
     create mode 100644 practice/test.txt

    一般会在文件管理器或用rm删除没用文件

    $ rm test.txt 

    此时Git知道有文件被删除,工作区和版本库不一致,

    $ git status
    位于分支 master
    尚未暂存以备提交的变更:
      (使用 "git add/rm <文件>..." 更新要提交的内容)
      (使用 "git checkout -- <文件>..." 丢弃工作区的改动)
    
        删除:     test.txt
    
    修改尚未加入提交(使用 "git add" 和/或 "git commit -a"

    此时有两种情况,一确实要从版本库删除文件,用git rm 删除该文件并git  commit,

    $ git rm test.txt
    rm 'practice/test.txt'
    $ git commit -m 'remove test.txt'  
    [master ed47d55] remove test.txt
     1 file changed, 0 insertions(+), 0 deletions(-)
     delete mode 100644 practice/test.txt
    $ git status
    位于分支 master
    无文件要提交,干净的工作区        #test.txt从版本库删除,在工作区也已经被删了

    二误删,从版本库中的最新版提取到工作区,

    git checkout -- test.txt
    渐变 --> 突变
  • 相关阅读:
    Javascript高级程序设计-对象
    获取访问来源
    jQuery 序列化表单数据 serialize() serializeArray()
    Web用户的身份验证及WebApi权限验证流程的设计和实现
    Asp.Net WebAPI中Filter过滤器的使用以及执行顺序
    ASP.NET Web API 过滤器创建、执行过程(二)
    ASP.NET Web API 过滤器创建、执行过程(一)
    MVC和Web API 过滤器Filter
    在ASP.NET Core Web API上使用Swagger提供API文档
    Json常用组件
  • 原文地址:https://www.cnblogs.com/lybpy/p/7802019.html
Copyright © 2020-2023  润新知