**
Git命令使用及tortoiseGit使用
**
Git是目前世界上最先进的分布式版本控制系统,首先,了解下什么是集中式和分布式。
集中式: – 版本库是集中存放在中央服务器的 – 最大的毛病就是必须联网才能工作 (Git的先前版本CVS及SVN都是集中式的版本控制系统)
分布式:分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。 分布式版本控制系统的安全性要高很多。
1、安装git(windows)
官网下载安装即可
dos下键入git,有提示信息安装成功
接着需要配置name和email:
命令行键入: $ git config --global user.name “Your Name”
$ git config --global user.email “email@example.com”
(用了–global参数,表示你这台机器上所有的Git仓库都会使用这个配置,
当然也可以对某个仓库指定不同的用户名和Email地址。)
2、git使用(常用)
-创建版本库:
--选择一个合适的地方,创建一个空目录
--通过git init命令把这个目录变成Git可以管理的仓库(repository)
--可以发现当前目录下多了一个.git的隐藏目录,删除这个.git则这个目录的取消跟踪
--再明确一下,所有的版本控制系统,其实只能跟踪文本文件的改动
-新建一个文件:写入一些内容: git is a version control system.
git is free software.
命令:git add readme.txt------把文件readme.txt添加到repository仓库
命令:git commit -m “说明信息”------光是添加到仓库并没有结束,必须提交至仓库----说明信息
有一个参数可不写它
Tips:因为commit可以一次提交很多文件,所以可以多次add不同的文件,及一次add多个文件
git add file1.txt
git add file2.txt file3.txt
git commit -m “add 3 files.”
再次修改文件后,使用git status命令
命令:git status------查看当前仓库状态
每次修改文件后,都可以add并commit给仓库(映射为一次快照)
命令:git diff------查看具体修改了什么内容,一般在文件修改后先git diff查看改了什么内容,在进行add和commit
不断对文件进行修改,然后不断提交修改到版本库里,类比游戏的存档
命令:git log------查看"存档",只会显示当前"存档"之前的log,而若已经回到以前的版本,当版本的未来版本是查不到的(可以用git reflog)
git log --pretty=oneline------显示为一行
"commit e47…"为版本的commid id
命令:git reflog------可以查看之前所有的版本文件
命令:git reset --hard HEAD^------HEAD指向master,HEAD后边的一个 ^ 表示回溯到HEAD之前一个版本,数量=回溯个数,回溯较多的时候:HEAD~45。 或者通过git reflog拿到id:git reset --hard commit e084…
分支与合并
在版本回退里,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支。截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支。HEAD严格来说不是指向提交,而是指向master,master才是指向提交的,所以,HEAD指向的就是当前分支。
一开始的时候,master分支是一条线,Git用master指向最新的提交,再用HEAD指向master,就能确定当前分支,以及当前分支的提交点,每次提交,master分支都会向前移动一步,这样,随着你不断提交,master分支的线也越来越长。
当我们创建新的分支,例如dev时,Git新建了一个指针叫dev,指向master相同的提交,再把HEAD指向dev,就表示当前分支在dev上。从现在开始,对工作区的修改和提交就是针对dev分支了,比如新提交一次后,dev指针往前移动一步,而master指针不变。
假如我们在dev上的工作完成了,就可以把dev合并到master上。合并完分支后,甚至可以删除dev分支。删除dev分支就是把dev指针给删掉,删掉后,我们就剩下了一条master分支。
首先,我们创建dev分支,然后切换到dev分支。
命令:git checkout -b dev
加上-b参数表示创建并切换,相当于以下两条命令:
git branch dev
git checkout dev
命令:git branch------列出所有分支,当前分支前面会标一个*号
然后,我们就可以在dev分支上正常提交,比如对readme.txt做个修改。–> 提交(add-commit)
dev的分支工作完成,我们可以切换回master分支 --> git checkout master
切换回master分支后,再查看一个readme.txt文件,刚才添加的内容不见了。因为那个提交是在dev分支上,而master分支此刻的提交点并没有变。
现在,我们把dev分支的工作成果合并到master分支上。
命令:git merge dev------以当前分支为主,将dev分支合并到当前分支(dev–>(合入)master)
合并后,再查看readme.txt的内容,就可以看到,和dev分支的最新提交是完全一样的。
合并完成后,就可以放心地删除dev分支了: git branch -d dev