$ git status
查看当前目录是否有文件变动。
$ git add 文件名1 文件名2 ...
将文件添加到缓存区(若要将当前目录下全部文件添加到缓存区,使用命令 $ git add .,末尾是英文标点符号".")
$ git commit -m "描述内容"
将缓存区的文件提交到仓库,并根据描述使HEAD指针指向新创建的仓库的节点("描述内容"可以不填写,表述描述为空)
$ git log
查看节点编码,用SHA1计算而得
$ git reset --hard 节点编码
返回当前仓库到已知的某一节点,节点编码不用写完全,前7位即可(HEAD∧表示上一节点,HEAD∧∧表示上上节点)
$ git remote add origin git@github.com:用户名/仓库名.git
建立本地仓库与GitHub服务器上仓库的关联
$ git push -u origin master
首次推送本地仓库内容到GitHub服务器,推送master分支的内容
$ git push origin master
第二次及以后推送内容到GitHub服务器
$ git clone git@github.com:用户名/仓库名.git
克隆GitHub上的仓库,在本地以仓库(reponsitory)名建立一个文件夹,并下载仓库全部内容
$ git checkout -b dev
创建分支dev,并切换到分支dev,效果相当于 $ git branch dev 加上 $ git checkout dev
$ git branch
查看当前分支,列出当前所有分支,而正在使用的分支前有"*"符号
$ git merge dev
将dev分支上的工作成果合并到master主分支上
$ git branch -d dev
删除分支dev,$ git branch -D dev,强制删除分支
$ git log --graph --pretty=oneline --abbrev-commit --
显示日志,并呈现为线性关系
(更美观,方便的显示日志)
$ git log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen (%cr) %C(bold blue)<%an>%Creset'--abbrev-commit --
这样有点长了,我们可以这样:
$ git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen (%cr) %C(bold blue)<%an>%Creset' --abbrev-commit --"
然后,我们就可以使用这样的短命令了:
$ git lg
(查看日志方法,结束)
$ git merge --no-ff -m "描述内容" dev
默认合并分支的方式为 Fast forward 方式,即将 HEAD 指针指向分支dev的当前位置,而调用--no-ff将产生一个新指针,所以需要加入-m并附上描述内容
$ git stash
将当前分支的工作内容保存进stash队列
$ gti stash list
显示stash(储藏处)队列的内容,按“stash@{0}” 诸如此类数字变化的顺序排列
$ git stash apply stash@{0}
恢复stash@{0}的内容,但不删除stash@{0},若不写stash@{0},表示恢复上一条记录
$ git stash drop stash@{0}
删除stash@{0},若不写stash@{0},表示删除上一条记录
$ git stash pop
恢复并删除上一条储藏,若在pop后跟上stash的队列序号:stash@{0},则为制定队列
$ git remote -v
显示github主机上的详细分支,(fetch)抓取,(push)推送,如果没有推送权限,就看不到(push)地址
$ git push origin 分支名
origin为远程主机的默认名,推送不同分支,填写不同分支名,需要实时与远程主机同步,master是主分支,dev是开发分支,所有团队成员都在dev上面工作,
所以也需要与远程服务器同步
$ git checkout -b dev origin/dev
主机建立一个完全克隆远程主机分支dev内容的本地分支dev
$ git branch --set-upstream dev origin/dev
指定本地dev与远程主机上的dev连接,之后可以使用 $ git pull 抓取内容
$ git pull
把最新的提交从origin/分支名上抓下来
$ git tag 标签名 -m "描述内容" commit 指针编码
给指定commit指针编码添加“标签名“的tag,若没有描述内容可省略 -m "描述内容"
$ git push origin 标签名
将本地”标签名“的内容推送到远程主机
$ git tag -d 标签名
删除指定标签名内容
$ git push origin :refs/tags/标签名
删除远程主机上的标签名内容
* 标签名一般为v1.0,并以此类推