$ git config --global user.name "zhouxiaowan"
$ git config --global user.email "1012596161@qq.com"
$ mkdir learngit //新建一个空目录
$ cd learngit //打开learngit目录
$ pwd //pwd
命令用于显示当前目录;
$ git init //通过git init
命令把这个目录变成Git可以管理的仓库:
$ git add readme.txt//添加文件,也可以添加好几个例如$ git add readme.txt readme2.txt readme3.txt
$ git commit -m "wrote a readme file" // -m
后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。
$ git status // git status
命令可以让我们时刻掌握仓库当前的状态,上面的命令告诉我们,readme.txt被修改过了,但还没有准备提交的修改。
$ git diff readme.txt //顾名思义就是查看difference,显示的格式正是Unix通用的diff格式,可以从上面的命令输出看到,我们在第一行添加了一个“distributed”单词。知道了对readme.txt作了什么修改后,再把它提交到仓库就放心多了.
$ git log //git log
命令显示从最近到最远的提交日志,我们可以看到3次提交,最近的一次是append GPL
,上一次是add distributed
,最早的一次是wrote a readme file
。如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline
参数:
$ git log --pretty=oneline
$ git reset --hard HEAD^ // 退回到上一个版本,上上一个版本就是HEAD^^
,当然往上100个版本写100个^
比较容易数不过来,所以写成HEAD~100
。
$ git reset --hard 3628162 // 版本号,版本号没必要写全,前几位就可以了,Git会自动去找。当然也不能只写前一两位,因为Git可能会找到多个版本号,就无法确定是哪一个了。
$ git reflog // 当找不到commit id时,$ git reflog 操作用来记录每一次命令
$ git checkout --readme.txt //命令git checkout -- readme.txt
意思就是,把readme.txt
文件在工作区的修改全部撤销,这里有两种情况:
一种是readme.txt
自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
一种是readme.txt
已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
总之,就是让这个文件回到最近一次git commit
或git add
时的状态。
$ git reset HEAD readme.txt //可以把暂存区的修改撤销掉(unstage),重新放回工作区
$ git rm test.txt //命令git rm
用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。