Git基础

Git基础


获取项目的git仓库

从当前目录初始化

在当前项目的目录先初始化git,然后将需要使用git管理的添加进去。

 
 
  1. $ git init
  2. $ git add *.c
  3. $ 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所使用的简化了的正则表达式。

 
 
  1. # 此为注释 – 将被 Git 忽略
  2. *.a # 忽略所有 .a 结尾的文件
  3. !lib.a # 但 lib.a 除外
  4. /TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
  5. build/ # 忽略 build/ 目录下的所有文件
  6. 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模式匹配。

 
 
  1. git rm log/\*.log
  2. git rm \*~

如上,第一行删除log/目录下扩展名为.log的文件,第二行递归删除当前目录下
以及其子目录总所有以~结尾的文件。

移动文件(重命名文件)

git mv fileFrom fileTo
这一条命名相当于:

 
 
  1. mv *fileFrom* *fileTo*
  2. git rm *fileFrom*
  3. 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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值