码迷,mamicode.com
首页 > 其他好文 > 详细

2 修改与恢复

时间:2017-11-12 23:02:27      阅读:335      评论:0      收藏:0      [点我收藏+]

标签:res   repo   指针   大于等于   under   记录   ons   历史   异常   

将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

 

2 修改与恢复

标签:res   repo   指针   大于等于   under   记录   ons   历史   异常   

原文地址:http://www.cnblogs.com/lybpy/p/7802019.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!