一、什么是git?
官方定义:git是版本控制工具。
这里的版本其实是每一次发布的代码,git会把每一次提交的代码都保存下来,并给它一个叫做“版本号”的编号。这类似于期刊出版的过程,每一次出版都有它的期号。
二、为什么使用git?
- git具有备份文件的功能,允许我们找到修改前的文件,可以“反悔”
- git具有分支机制,像写小说,可以分出几条支线。这样允许我们在开发主程序的同时,开发额外的功能。这样同样使多人开发变得简便,只有每个人开发自己的功能(支线),最后合并(连)起来即可。
三、常用命令
- 个人信息相关
- 用户名和联系邮箱
git config --global user.name '这里写用户名'
git config --global user.email '这里写邮箱地址'
- 本地项目相关
- 初始化一个项目。
git init <projectName(如果不写默认初始化当前目录)>
- 查看项目状态
git status <-s如果写上,给出简洁形式>
- 添加文件到暂存区
git add <文件目录(如果是.就是当前目录)>
- 提交暂存区文件到项目
git commit -m '这里写更改说明'
- 查看更改历史
git log <--oneline(如果写上,就显示简洁版)>
- 添加分支
git branch (分支名) // 如果不写分支名,会列出所有分支信息
- 切换分支
git checkout (分支名)
- 合并分支
git merge (分支名) // 这是将分支合并到当前分支
- 删除分支
git brand -d (分支名)
- 给重要结点打标签
git tag -a (标签名) <版本(结点)编号,如果不写,默认给当前结点打编号>
// -a应该是annotate(注解)
- 查看标签
git tag
- 在日志中图形化查看标签
git log --oneline --decorate --graph
- 远程仓库相关
- 克隆项目到本地
git clone (git仓库地址) <本地项目别名,如果不写默认使用仓库的名字>
- 添加远程仓库
git remote add (仓库名) (仓库地址)
- 获取仓库的新信息
git fetch
- 合并分支
git merge
- 获取信息并合并分支
git pull
- 推送信息
git push -u (仓库名字) (分支) // 默认的远程仓库名称是origin