git学习总结

看了廖雪峰的git教程,很详细,并且小结很到位,在此自己再根据需要总结一下,方便今后操作查阅,详情可看git教程
PS:紧记Git跟踪并管理的是修改,而非文件。

1. 创建版本库

git init --> 初始化一个Git仓库

添加文件到git仓库分2步:

  • git add
  • git commit -m ps:-m后面输入的是本次提交的有意义说明
2.版本回退(后悔药)

Git允许我们在版本的历史之间穿梭 git reset --hard commit_id

  • 回到过去,使用 git log 查看 commit_id
  • 重返未来,使用 git reflog 查看commit_id
3.工作区、暂存区、版本库的概念

Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念。

  • 工作区:电脑里能看到的目录
  • 暂存区: stage/index ,存放在 ".git目录下" 下的index文件(.git/index)中,so,也可叫作索引(index)
  • 版本库:工作区有个隐藏目录.giit ,是Git的版本库

修改提交及chexiu操作流程:
工作区-- git add ---> 暂存区 --git commit -m --> 版本库
版本库--版本回退(未推送到远程库)-->暂存区--git reset head -->工作区--git checkout -- file-->丢弃工作区的修改

简言之,撤销修改可分4种
1.没有git add时,用git checkout -- file

2.已经git add时,先git reset HEAD 回退到1.,再按1.操作

3.已经git commit时,用git reset回退版本

4.如已推送到远程库,GG?

这里说说较为难理解的一个点----暂存区

  • 暂存区如概念所说是一个index文件

  • git init 初始化仓库的时候会生成一个文件夹.git(普遍隐藏,可设置显示隐藏文件夹),里面内容如下


    git.jpg
    git-无暂存区.jpg
  • 添加一个文本text1,并执行git add . 操作,.git下多了个index文件,它就是一个暂存区,也被成为索引 index

    出现暂存区文件index.jpg

  • 执行git status,可见文件被修改,处于暂存区待提交commit状态

    1.jpg

  • 此时再来看看暂存区的内容git ls-files --stage

    2.jpg

  • 新增文件text2,并新增到暂存区,再次查看暂存区内容
    3.jpg
  • 这下便可理解,为何暂存区被称为索引(index)-- 指向文件的索引
    而真正的文件是存储在.git/objects目录,这里不详说,具体可查阅官方资料

  • 下面将所有文件提交,查看工作区、暂存区的状态,查看暂存区的内容

    4.jpg

    由此可见commit后工作区没有新增/修改的文件,暂存区也没有待提交的文件,暂存区内容不变,并不像我们感性上的被清空,如真的需要删除暂存区的内容,其实就是删除index文件的内容,存储在.git/objects目录下的真正文件是不会被删除的,如想删除真正的文件,操作git rm --cached
    5.jpg

  • 在理解了暂存区的基础上,我们就能很好的理解了以下命令


    6.jpg

你可能感兴趣的:(git学习总结)