1.经过git init命令把这个目录变成Git能够管理的仓库:git
$ git init Initialized empty Git repository in /Users/michael/learngit/.git/
2.用命令git add告诉Git,把文件添加到仓库:app
$ git add readme.txt
3.用命令git commit告诉Git,把文件提交到仓库:指针
$ git commit -m "wrote a readme file" [master (root-commit) eaadf4e] wrote a readme file 1 file changed, 2 insertions(+) create mode 100644 readme.txt
简单解释一下git commit命令,-m后面输入的是本次提交的说明,能够输入任意内容,固然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。
git commit命令执行成功后会告诉你,1 file changed:1个文件被改动(咱们新添加的readme.txt文件);2 insertions
4.运行git status命令查看结果日志
$ git status On branch master Changes not staged for commit: (use "git add <file>..." to update what will be committed) (use "git checkout -- <file>..." to discard changes in working directory) modified: readme.txt no changes added to commit (use "git add" and/or "git commit -a")
git status命令可让咱们时刻掌握仓库当前的状态,上面的命令输出告诉咱们,readme.txt被修改过了,但尚未准备提交的修改。
5.git diff 查看之前的修改类容,git diff HEAD -- readme.txt命令能够查看工做区和版本库里面最新版本的区别code
$ git diff readme.txt diff --git a/readme.txt b/readme.txt index 46d49bf..9247db6 100644 --- a/readme.txt +++ b/readme.txt @@ -1,2 +1,2 @@ -Git is a version control system. +Git is a distributed version control system. Git is free software.
要随时掌握工做区的状态,使用git status命令。 若是git status告诉你有文件被修改过,用git diff能够查看修改内容。
6.查看历史记录要随时掌握工做区的状态,使用git status命令。若是git status告诉你有文件被修改过,用git diff能够查看修改内容。blog
$ git log commit 1094adb7b9b3807259d8cb349e7df1d4d6477073 (HEAD -> master) Author: Michael Liao <askxuefeng@gmail.com> Date: Fri May 18 21:06:15 2018 +0800 append GPL commit e475afc93c209a690c39c13a46716e8fa000c366 Author: Michael Liao <askxuefeng@gmail.com> Date: Fri May 18 21:03:36 2018 +0800 add distributed commit eaadf4e385e865d25c48e7ca9c8395c3f7dfaef0 Author: Michael Liao <askxuefeng@gmail.com> Date: Fri May 18 20:59:18 2018 +0800 wrote a readme file
git log命令显示从最近到最远的提交日志,咱们能够看到3次提交,最近的一次是append GPL,上一次是add distributed,最先的一次是wrote a readme file。it
$ git log --pretty=oneline 1094adb7b9b3807259d8cb349e7df1d4d6477073 (HEAD -> master) append GPL e475afc93c209a690c39c13a46716e8fa000c366 add distributed eaadf4e385e865d25c48e7ca9c8395c3f7dfaef0 wrote a readme file
7.回退上一个版本可使用git reset命令io
$ git reset --hard HEAD^ HEAD is now at e475afc add distributed
--hard参数有啥意义?这个后面再讲,如今你先放心使用。
看看readme.txt的内容是否是上个版本
8.Git提供了一个命令git reflog用来记录你的每一次命令:ast
$ git reflog e475afc HEAD@{1}: reset: moving to HEAD^ 1094adb (HEAD -> master) HEAD@{2}: commit: append GPL e475afc HEAD@{3}: commit: add distributed eaadf4e HEAD@{4}: commit (initial): wrote a readme file
HEAD指向的版本就是当前版本,所以,Git容许咱们在版本的历史之间穿梭,使用命令git reset --hard commit_id。 穿梭前,用git log能够查看提交历史,以便肯定要回退到哪一个版本。 要重返将来,用git reflog查看命令历史,以便肯定要回到将来的哪一个版本。
工做区有一个隐藏目录.git,这个不算工做区,而是Git的版本库。
Git的版本库里存了不少东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为咱们自动建立的第一个分支master,以及指向master的一个指针叫HEAD。
test
把文件往Git版本库里添加的时候,是分两步执行的:
第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用git commit提交更改,实际上就是把暂存区的全部内容提交到当前分支。
由于咱们建立Git版本库时,Git自动为咱们建立了惟一一个master分支,因此,如今,git commit就是往master分支上提交更改。
你能够简单理解为,须要提交的文件修改统统放到暂存区,而后,一次性提交暂存区的全部修改。
git add命令实际上就是把要提交的全部修改放到暂存区(Stage),而后,执行git commit就能够一次性把暂存区的全部修改提交到分支。
一旦提交后,若是你又没有对工做区作任何修改,那么工做区就是“干净”的:
$ git status On branch master nothing to commit, working tree clean
9.git checkout -- file能够丢弃工做区的修改:
$ git checkout -- readme.txt
命令git checkout -- readme.txt意思就是,把readme.txt文件在工做区的修改所有撤销,这里有两种状况:
一种是readme.txt自修改后尚未被放到暂存区,如今,撤销修改就回到和版本库如出一辙的状态;
一种是readme.txt已经添加到暂存区后,又做了修改,如今,撤销修改就回到添加到暂存区后的状态。
总之,就是让这个文件回到最近一次git commit或git add时的状态。
git checkout -- file命令中的--很重要,没有--,就变成了“切换到另外一个分支”的命令,咱们在后面的分支管理中会再次遇到git checkout命令。
10.Git一样告诉咱们,用命令git reset HEAD
$ git reset HEAD readme.txt Unstaged changes after reset: M readme.txt
git reset命令既能够回退版本,也能够把暂存区的修改回退到工做区。当咱们用HEAD时,表示最新的版本。
场景1:当你改乱了工做区某个文件的内容,想直接丢弃工做区的修改时,用命令git checkout -- file。 场景2:当你不但改乱了工做区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD <file>,就回到了场景1,第二步按场景1操做。 场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。
$ git checkout -- test.txt
11.命令git rm用于删除一个文件。若是一个文件已经被提交到版本库,那么你永远不用担忧误删,可是要当心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。