Git常用命令备忘

目录

1.git clone

重要的事情在前面说,clone之前需要init!

$ cd proj-dir
$ git init

clone命令会在本地主机生成一个目录,与远程主机的版本库同名。
如果要指定不同的目录名,可以将目录名作为git clone命令的第二个参数。

$ git clone <版本库的网址>
$ git clone <版本库的网址> <本地目录名>

比如,克隆jQuery的版本库。

$ git clone https://github.com/jquery/jquery.git

clone支持HTTP(s)、SSH、Git、FTP等协议。

2.git remote

git remote命令列出所有远程主机。
克隆版本库的时候,所使用的远程主机自动被Git命名为origin。

$ git remote
origin

使用-v选项,可以参看远程主机的网址。

$ git remote -v
origin  git@github.com:jquery/jquery.git (fetch)
origin  git@github.com:jquery/jquery.git (push)

如果想用其他的主机名,需要用git clone命令的-o选项指定。

$ git clone -o jQuery https://github.com/jquery/jquery.git
$ git remote
jQuery

3.git fetch

如果远程仓库的代码有更新,我们需要将这些更新取到本地。
通常建议在修改本地代码前做这件事。

$ git fetch <远程主机名>
$ git fetch <远程主机名> <分支名>

如果不指定分支名,则取回所有分支的更新。
如果指定分支名,则仅取回指定分支的更新。

那么,我怎么知道取哪个分支?
git branch命令的-r选项,可以用来查看远程分支,-a选项查看所有分支。

$ git branch -r
origin/master

$ git branch -a
* master
remotes/origin/master

上面的命令表示,本地主机的当前分支是master,远程分支是origin/master。

fetch只能从远程仓库取得代码,还没有合并到本地的代码中去。需要使用git merge命令或者git rebase命令,在本地分支上合并远程分支。

$ git merge origin/master
# 或者
$ git rebase origin/master

可是可是,如果我不想合并到现在的分支上怎么办呢。可以使用git checkout命令创建一个新的分支。

$ git checkout -b newBrach origin/master

上面命令表示,在origin/master的基础上,创建一个新分支。

4.git pull

取回远程主机某个分支的更新,并且与本地的指定分支合并。
同最开始的图上看,是不是相当于fetch+checkout?

$ git pull <远程主机名> <远程分支名>:<本地分支名>
$ git pull origin next:master

表示取回origin主机的next分支,与本地的master分支合并。
如果远程分支是与当前分支合并,则冒号后面的部分可以省略。

$ git pull origin next

也就是先做git fetch,再做git merge。

$ git fetch origin
$ git merge origin/next

5.git add

把修改信息添加到index暂存区。
添加所有文件:

$ git add -A

添加指定文件到暂存区:

$ git add <文件1> <文件2>

也可以指定文件夹:

$ git add <文件夹>

删除文件,并且将删除信息也添加到暂存区:

$ git rm <文件1> <文件2>

重命名,并且将重命名信息也添加到暂存区:

$ git mv <原文件名> <新文件名>

6.git commit

把暂存区的修改,提交到仓库:

$ git commit -m "信息"

原则上是,每一个原子修改,都作一次提交。

7.git push

将本地分支的更新,推送到远程主机。

$ git push <远程主机名> <本地分支名>:<远程分支名>   

通常本地分支名和远程分支名都同名,可以省略远程分支名。

$ git push origin master

表示将本地的master分支推送到origin主机的master分支。

其他

显示暂存区和工作区的差异:

$ git diff    

显示有变更的文件:

$ git status
上一篇:Git基础管理_UnityUpm包制作


下一篇:LeetCode_557.反转字符串中的单词 III