Git基础
获取项目的git仓库
从当前目录初始化
在当前项目的目录先初始化git,然后将需要使用git管理的添加进去。
$ git init
$ git add *.c
$ git conmmit -m 'initial project version'
从现有的仓库克隆
使用git clone url [dirName] 来将远端项目克隆至名为dirName的文件夹下,文件夹若缺省则为拷贝至当前目录,且文件夹名与项目名一样。
Git支持许多数据传输协议,可以是git://协议,http(s)://或者user@server:/path.git表示的SSH传输协议。
记录每次更新到仓库
使用Git管理的工作目录下的文件的两种状态:已跟踪(tracked files),未跟踪(untracked files),已跟踪的文件是纳入Git管理的文件,只有已跟踪的文件才有之前所说的文件的三种状态。
检查当前文件状态
当前目录下执行git status,输出的提示相当详细,包括该使用何种命令应对不同状态的文件。
跟踪新文件
执行git add file ,如果添加的是目录,则需要递归目录下的所有文件。执行之后,文件的 此时此刻 的版本将被放到暂存区,等待下次提交。
暂存已修改文件
运行git add file ,将本次修改保存到暂存区(git add这一命令根据文件状态的不同,有多种用途)。
对于已经暂存了的文件又做出修改,那么文件又变成已修改的状态,需要再次使用git add来暂存文件,否则暂存区存放的只是上次修改的文件。
忽略某些文件
在工作目录下新建.gitignore这一文件,将所有需要无需纳入Git管理,也不希望总是提示为未跟踪的文件列入,来忽略这些文件。
.gitignore文件的格式规范:
- 所有空行或以注释号#开头的行都会被git忽略;
- 可以使用标准的glob模式匹配;
- 匹配模式最后跟反斜杠(/)说明要忽略的是目录;
- 要忽略指定模式以外的文件或目录,可以在模式匹配前加惊叹号(!)取反。
注:glob模式是指shell所使用的简化了的正则表达式。
# 此为注释 – 将被 Git 忽略
*.a # 忽略所有 .a 结尾的文件
!lib.a # 但 lib.a 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/ # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
查看已暂存和未暂存的更新
- git diff 比较工作目录中当前文件和暂存区快照之间的差异。及已修改的和已暂存的文件的差异。
- git diff --cached或高版本的Git可以使用git diff --staged来查看已暂存的文件和上次提交时的快照之间的差异。
提交更新
每次提交之前,先用git status检查看是否所有文件已经暂存,然后用git commit提交更新。这种方式会打开文本编辑器,第一行为空,在这里写上更新说明。可以使用-v参数,将修改差异的每一行都包含到注释中。也可已使用-m参数,git commit -m "the description of the update",直接协商提交说明。
跳过使用暂存区,直接提交更新
git commit -a,Git自动把已跟踪的文件暂存起来,一并提交,跳过git add操作。
移除文件
将已跟踪的文件从工作目录中删除:git rm file,如果删除之前修改过并且已经放到暂存区的话,需要使用强制删除选项-f,以防误删文件后丢失修改的内容。
将文件从Git仓库中移除但是仍保留在工作目录中:git rm --cached file,然后在.gitingnore文件中补上来忽略。
git rm后可以跟文件名货目录名,也可使用glob模式匹配。
git rm log/\*.log
git rm \*~
如上,第一行删除log/目录下扩展名为.log的文件,第二行递归删除当前目录下
以及其子目录总所有以~结尾的文件。
移动文件(重命名文件)
git mv fileFrom fileTo
这一条命名相当于:
mv *fileFrom* *fileTo*
git rm *fileFrom*
git add *fileTo*
查看提交历史
git log
一些常用参数
-p 按补丁格式显示每个更新之间的差异。
--stat 显示每次更新的文件修改统计信息。
--shortstat 只显示 --stat 中最后的行数修改添加移除统计。
--name-only 仅在提交信息后显示已修改的文件清单。
--name-status 显示新增、修改、删除的文件清单。
--abbrev-commit 仅显示 SHA-1 的前几个字符,而非所有的 40 个字符。
--relative-date 使用较短的相对时间显示(比如,“2 weeks ago”)。
--graph 显示 ASCII 图形表示的分支合并历史。
--pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline,short,full,fuller 和 format(后跟指定格式)。
撤销操作
修改最后一次提交
- 修改提交信息:git commit --amend
- 提交忘记暂存的某些文件:补上暂存操作,再使用--amend提交。
取消已暂存的文件
git reset HEAD file
在运行git status时,对于已经提交的文件会有该操作提示,所以不需要死记硬背。
取消对文件的修改
git checkout -- file
同样在运行git status时会有提示。该操作把已修改的未保存到暂存区的文件恢复到之前的版本,所有的修改内容将丢失。
注意:这样的操作有点危险,因为修改的内容将丢失。如果只是想回退到上一版本,保存当前修改,可以使用stashing和分支来处理。
记住,任何已经提交到Git的都可以被恢复。
远程仓库的使用
打标签
技巧和窍门
自动完成
可以像使用命令行自动补全那样按tab键两次在输入git命令时来输出补全提示。
如果使用的时Bash Shell,可以使用Git提供的自动补全脚本。
Git命令别名
例如:git config --global alias.ci commit
则 git ci=git commit