Git基础三步骤

首先要明确一点,对git的操作是围绕3个大的步骤来展开的(其实几乎所有的SCM都是这样)

  1. 从git取数据(git clone)
  2. 改动代码
  3. 将改动传回git(git push)

这3个步骤又涉及到两个repository,一个是remote repository,在远程服务器上,一个是local repository,在自己工作区上。其中 1, 3 两个步骤涉及到remote server/remote repository/remote branch,2 涉及到local repository/local branch。git clone 会根据你指定的remote server/repository/branch,拷贝一个副本到你本地,再git push之前,你对所有文件的改动都是在你自己本地的local repository来做的,你的改动(local branch)和remote branch是独立(并行)的。

在clone完成之后,Git 会自动为你将此远程仓库命名为origin(origin只相当于一个别名,运行git remote –v或者查看.git/config可以看到origin的含义)(guyue: 即origin是代表远程仓库的一个默认别名, 可以在项目工程目录中.git/config文件中查看或修改),并下载其中所有的数据,建立一个指向它的master 分支的指针,我们用(远程仓库名)/(分支名) 这样的形式表示远程分支,所以origin/master指向的是一个remote branch(从那个branch我们clone数据到本地),但你无法在本地更改其数据。

同时,Git 会建立一个属于你自己的本地master 分支,它指向的是你刚刚从remote server传到你本地的副本。随着你不断的改动文件,git add, git commit,master的指向会自动移动,你也可以通过merge(fast forward)来移动master的指向。

 $ git branch -a (to show all the branches git knows about)
  * master
    remotes/origin/HEAD -> origin/master
    remotes/origin/master
$ git branch -r (to show remote branches git knows about)
   origin/HEAD -> origin/master
   origin/master

可以发现,master就是local branch,origin/master是remote branch

(master is a branch in the local repository. remotes/origin/master is a branch named master on the remote named origin)

$ git diff origin/master master

show me the changes between the remote master branch and my master branch

需要注意的是

remotes/origin/master和origin/master的指向是相同的

$ git diff origin/master remotes/origin/master

放弃修改

场景:修改了一个或一堆文件(这些文件修改前是已经存在的),但是还未执行 git add 到暂存区,想放弃这些修改

如果只修改了一个文件,以 README.md 文件为例

$ git checkout -- README.md

如果修改了多个文件,要一次性放弃所有文件的修改

$ git checkout .

放弃commit

场景:已经git add . ,并进行git commit -m 'xxx'

如果不删除工作空间改动代码,撤销commit,并且撤销git add . 操作

$ git reset --mixed HEAD^

--mixed为默认参数,git reset --mixed HEAD^ git reset HEAD^ 效果是一样的。

如果不删除工作空间改动代码,撤销commit,不撤销git add .

$ git reset --soft HEAD^

如果要删除工作空间改动代码,撤销commit,撤销git add .

$ git reset --hard HEAD^

关于git push origin master

origin指定了你要push到哪个remote。

master其实是一个“refspec”,正常的“refspec”的形式为”+:”,冒号前表示local branch的名字,冒号后表示remote repository下 branch的名字。注意,如果你省略了,git就认为你想push到remote repository下和local branch相同名字的branch。听起来有点拗口,再解释下,push是怎么个push法,就是把本地branch指向的commit push到remote repository下的branch,比如:

$ git push origin master:master

在local repository中找到名字为master的branch,使用它去更新remote repository下名字为master的branch,如果remote repository下不存在名字是master的branch,那么新建一个。

$ git push origin master

等价于“git push origin master:master”。

$ git push origin master:refs/for/mybranch

在local repository中找到名字为master的branch,用他去更新remote repository下面名字为mybranch的branch。

$ git push origin HEAD:refs/for/mybranch

HEAD指向当前工作的branch,master不一定指向当前工作的branch,所以我觉得用HEAD还比master好些。

$ git push origin :mybranch

再origin repository里面查找mybranch,删除它。用一个空的去更新它,就相当于删除了。


Git比较本地仓库和远程仓库的差异

假设本地分支为hexo,远程仓库origin的分支为master

首先更新本地的远程分支

$ git fetch origin

然后我们可以查看一下远程仓库有而本地仓库没有的commit信息

$ git log hexo..origin/master

最后查看具体文件差异(改动的地方)

$ git diff --stat hexo origin/master

将远程存储库中的更改合并到当前分支中

$ git pull origin master:hexo

如果当前分支已经是hexo,那么可以简写成

$ git pull origin master

在某些场合,Git会自动在本地分支与远程分支之间,建立一种追踪关系(tracking)。比如,在git clone的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master分支自动”追踪”origin/master分支。

Git允许手动建立追踪关系

$ git branch --set-upstream hexo origin/master

如果当前分支与远程分支存在追踪关系,git pull 可以简写成

$ git pull origin

Git创建新分支并把新分支上传到Github远程仓库

用Git创建一个分支,这个分支在远程仓库上是没有的,把这个新分支推送到远程仓库中。

创建分支并切换到该分支

$ git checkout -b hogwarts

推送新分支到远程仓库

$ git push origin HEAD -u

在这里插入图片描述

在Github中查看

在这里插入图片描述

查看本地已经commit,但是没有push的记录

git cherry -v

在这里插入图片描述
或者

git log hexo ^origin/hexo

在这里插入图片描述
注意,hexo^origin/hexo之间有一个空格

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐