将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