git(一)-git入门,版本库初始化以及常用命令操作

初始化版本库
第一步:git的安装,到官网下载即可(https://git-scm.com/)Windows下傻瓜式安装,安装完毕会生成git shell客户端,这个客户端在Windows下是一个模拟Linux的窗口,支持大部分的Linux的命令操作:
第二部:创建一个目录,然后进入目录,将此文件夹下作为项目的root,然后执行:git init 初始化版本库:

这里写图片描述

初始化之后在文件夹下的所有操作都会纳入到版本库的管理,此时需要说明一下git的三种状态:
这里写图片描述

已修改:文件修改之后的状态
已暂存:文件add到暂存区的状态
已提交:文件提交到远程版本库的状态

git常用命令简要:

  • 获得版本库
    • git init
    • git clone
  • 版本管理
    • git add 将文件存放道暂存区
    • git commit 将暂存区文件提交到远程版本库
    • git rm 删除文件,剥离版本库的管理
  • 查看信息
    • git help 帮助
    • git log 查看提交日志
    • git diff 比较文件的差别。可以是已修改的状态的文件和暂存区文件的差别,也可以是暂存区和远程版本库的文件的差别
  • 远程协作
    - git pull 把远程版本库的文件拉取到本地
    - git push 将本地版本库的文件推送到远程

git版本库的所有信息都在mygit的.git文件夹下边,如果我们删除此文件夹,那区别就是进入mygit这个目录的时候命令不会有诸如”(master)”这样的提示性的标示。
这里写图片描述

.git目录下边的文件保存了当前版本库的所有信息,一般不要手动修改,只能通过命令去修改:
这里写图片描述

新建一个文件:
这里写图片描述

新建一个文件之后当前工作区发生来了变化,那么怎么查看当前工作区的状态呢?

查看工作区状态:
git status 命令
这里写图片描述
很明显文件的状态是未追踪的状态(untracked),文件处理修改状态。

将已修改的文件加入到暂存区:
git add test.txt 将文件添加到暂存区当中。

add完毕之后再去查看版本库状态:
这里写图片描述
可以看到红色提示 new file : test.txt 意思是对于暂存区是一个新的文件,等待提交。
除了提示这是个新的文件之外,还有一句:use “git rm –cached …” to unstage)意思是我们可以将某个文件会退到已修改状态,即,从暂存区删除:
这里写图片描述
取消之后再去git status 就会回到文件刚刚创建的时候一样的状态。同样的道理我们再次git add test.txt 进去到暂存区恢复刚才的状态,接着我们下边的内容。

文件的提交(commit):
文件添加到暂存区之后接下来我们对文件进行提交到远程版本库:
git commit
当我们输入完命令回车之后会出现一个编辑器:
这里写图片描述
其中注释说明的意思是:当前提交需要添加提交说明,如果输入空内容忽略本次提交。我们什么也没有输入然后保存退出,出现:
这里写图片描述

Aborting commit due to empty commit message. 意思是由于本次提交没有添加说明,当前提交被取消终止,这一点和svn有很大的不同,svn可以不添加提交说明也可以提交成功,而git是不允许的。
我们添加提交说明,然后保存退出:
这里写图片描述

此时出现提交成功的提示:
这里写图片描述
create mode 100644 test.txt 即创建模式。此时再去查看git status:
这里写图片描述
意思是没有任何可以提交的文件。

查看提交历史:
git log
查看当前版本库的提交历史:
这里写图片描述
commit a0e67a4d3d6aa80d140e97d002828ec60911b8ff 这个提交id是一个摘要值,通过sha1计算出来的,sha1和MD5很相似,都是不可逆的。
author是提交人,date是提交的时间。
接下来我们要修改下名字和邮箱,对于user.email和user.name有三种方式可以设置:

  • /etc/gitconfig (针对于整个OS,不常用) git config –system
  • ~/.gitconfig(很常用) git config –global
  • 针对于特定项目的 位于当前项目的 .git/config文件中。 git config –local
    我们针对于第二种和第三种情况进行说明:
    git config –global
    首先进入.git目录查看 config文件内容:
    git config命令一些参数:
    这里写图片描述
    config文件内容:
    这里写图片描述
    紧接着:
    git config –local user.name ‘CeaserWang’
    git config –local user.email ‘xxx@xxx.com
    进行配置用户和邮箱,此时我们可以展示一下:
    git config user.name
    git config user.email
    同时再次查看config文件会发现user.name和user.email都存在了。
    这里写图片描述
    或者 git config –list查看所有配置参数
    git config –local user.name ‘CeaserWang’
    git config –local user.email ‘xxx@xxx.com‘ 这些命令也可以用来修改,再说一下删除:
    git config –local –unset user.name
    这里写图片描述
    接下我们回到mygit根目录,修改下test.txt文件,然后git staus 查看状态:
    这里写图片描述
    这时提示信息又发生一些变化。
    modified: test.txt意思是已经修改了。
    (use “git checkout – …” to discard changes in working directory 意识是 使用git checkout – 命令丢弃刚才的修改。
    首先我们的文件修改之后加入了一行文字(welcome)然后状态是modified状态,此时我们使用git checkout 命令回退刚才的修改:
    这里写图片描述
    会发现刚下的修改会取消了,状态回到愿原来的状态。这个命令要小心一点,因为文件没有放到版本库里边,真的丢弃了就找不回来了。

另外git commit的提交说明可以直接:git commmit -m ‘提交说明’
提交日志时间是按照倒序的排列:
这里写图片描述