#Git基本命令# ##Git初始化## 查看Git的版本信息:
git --version
对于Git的首次使用,需要设置Git的全局信息,这些信息主要涉及版本提交时的提交信息,Git所使用的默认编辑器等。
配置自己的用户名和邮件地址:
git config --global user.name "Yourname"
git config --global user.email "[email protected]"
在Git命令输出中开启颜色显示:
git config --global color.ui true
使用Git创建一个版本库,只需要在Git Bash中进入到版本库所在的目录然后执行命令:
git init
右或者对于1.6.5或更新的Git版本,可以直接在git init
后加上目录名,自动完成目录的创建。
##Git添加文件##
初始化了版本库后,该目录就成了工作区,而且会在该目录下创建一个隐藏的文件夹.git
文件夹,该文件夹就是Git的版本库了。
初始化完成后,即可往版本库中添加文件了。假如添加了一个文件README.md,可以使用命令
git add README.md
将该文件添加进版本库,但是光执行该命令是不够的,因为该命令只是将更改提交到缓存区,还需要执行一次提交操作才能将文件真正添加进版本库:
git commit -m "comment"
-m
后的"comment"
为提交说明,对于Git来说是不能省略,强制要求的。
显示版本库.git目录所在的位置:
git rev-parse --git-dir
显示工作区的根目录:
git rev-parse --show-toplevel
有时,在忘了对Git进行初始化设置用户名和email等信息时,Git会自动生成一个猜测的信息,这些可能是错误的,但是因为已经提交了,所以需要对提交的信息进行修改,在用git config --global
进行配置完之后,可以使用:
git commit --amend --allow-empty --reset-author
进行修改,--amend
是表示对刚刚的提交进行修改而不产生另外新的提交,--allow-empty
表示允许空白提交,这是因为要进行修补的提交是一个空白提交(默认情况下Git是不允许在用户信息空白的情况下提交的,为了说明更改提交信息,使用--allow-empty
就可以提交空白的信息)。--reset-autor
将Author的Id同步修改,否则只印象提交者的Id,使用该参数也会重置AuthorDate的信息。
显示提交日志
git log --stat
##Git分支创建及删除## 关于git分支,没有进行真正的大的软件开发项目,对分支没什么概念。但是,从网上查阅的资料和个人理解,对于项目而言,可能需要针对不同的需求(无论是客户需求或者是内部开发过程需求),需要有一些特殊的特性,这些特性不是所有客户需要的或者只是做内部研究使用的,这样就需要在当前的主开发分支上分离出一个分支来添加该特性,以免跟当前开发主分支混淆。
分支其实是一个提交记录的指针,所以其会随着分支提交而移动,指向当前的最新分支提交。
创建一个分支可以使用:
git branch YourBranchName
但是这样创建后当前的工作区还是在主分支上,并不会自动切换到新创建的分支上,还需要:
git checkout YourBranchName
如果想偷懒,可以用-b
参数直接创建分支并切换到新分支上:
git checkout -b YourBranchName
创建分支之后就可以在分支上进行修改添加等操作,然后推送:
git push -u origin YourBranchName
其中-u
的意思是让git记录本地remote和branch的对应,这样下次用无参数的git pull
时,将自动抓取该分支的数据。
当项目研究结束添加特性觉得成熟可行,或者因为需求更变,本来只有部分人需要的特性大家都需要的时候,就需要把添加特性的分支合并到需要改特性的分支中去:
git merge YourMergeBrachName
当然,在合并之前,需要先将当前工作区转入到合并目标的那个分支中去git checkout YourTargetBranchName
对于分支的删除必须先转到待删除分支之外的其它分支工作区内才能进行,否则会提示删除错误。切换工作区后就可以进行删除了:
git branch -D YourBranchName
之所以使用参数-D
而不是-d
是因为git为了防止删除分支时避免数据丢失,默认禁止删除尚未合并的分支。参数-D
则强制删除尚未合并的分支。
现在是本地的分支被删除了,但是在远程服务器上(如果有)的分支还未被删除,所以还需要删除远程服务器上的分支:
git push origin :YourBranchName
注意命令里的:
号当然,该命令必须在远程服务器中未把待删除分支当做默认分支的时候才能成功,如果在远程服务器上待删除分支被设为默认分支,那么需要设置成其他分支为默认分支才可以成功删除。
##里程碑创建和删除## 里程碑在项目开发过程中通常对应项目一个具有特殊意义的版本,或者是可以供用户公测,或者是项目的第n版本,或者是供客户查看的演示版本等。在Git中,里程碑(tag)其实就是一个标签,其跟分支是类似的,只不过里程碑是静态的,也即其不会随着项目进程的进展而改变,除非你删除更改它。Git中包含几种不同类别的tag:
- 轻量级里程碑:用
git tag <tagname> [<commit>]
创建,引用直接指向一个提交对象<commit>
- 带说明的里程碑:用
git tag -a <tagname> [<commit>]
命令创建,并且在创建时需要提供创建里程碑的说明。Git会创建一个tag对象保存里程碑说明、里程碑的指向、创建里程碑的用户等信息,里程碑引用指向该tag对象; - 带签名的里程碑:用
git tag -s <tagname> [<commit>]
命令创建。是在带说明的里程碑的基础上引入了PGP签名,保证了所创建的里程碑的完整性和不可拒绝性。
创建里程碑如下:
git tag -m "your comment" YourTag1 HEAD^
git tag -m "your comment" YourTag2
git tag YourTag3
其中HEAD^
不知道是什么意思,根据网上资料,HEAD
是指当前分支,但是加个^
不知道是什么东西。
查看创建的新建里程碑:
git tag -l -n1
其中-n1
表示最多显示1行的里程碑说明。
然后将里程碑推送到远程版本库:
git push origin refs/tags/*
删除本地里程碑:
git tag -d YourTagName
删除远程版本库里程碑:
git push origin :YourTagName