2019独角兽企业重金招聘Python工程师标准>>>

1、origin/master : 一个叫 origin 的远程库的 master 分支

2、HEAD指向当前工作的branch,master不一定指向当前工作的branch

3、Git  push  origin  本地分支A : 远程分支B ---> push 本地分支A到远程库origin的分支B

首先要明确一点,对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是独立(并行)的。Gitk显示的就是local repository。

在clone完成之后,Git 会自动为你将此远程仓库命名为origin(origin只相当于一个别名,运行git remote –v或者查看.git/config可以看到origin的含义),并下载其中所有的数据,建立一个指向它的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)* masterremotes/origin/HEAD -> origin/masterremotes/origin/master
$git branch -r (to show remote branches git knows about)origin/HEAD -> origin/masterorigin/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 Push:

git push origin master

origin指定了你要push到哪个remote

master其实是一个“refspec”,正常的“refspec”的形式为”+<src>:<dst>”,冒号前表示local branch的名字,冒号后表示remote repository下 branch的名字。注意,如果你省略了<dst>,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 (省略了<dst>,等价于“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,删除它。用一个空的去更新它,就相当于删除了)

转载于:https://my.oschina.net/fairy1674/blog/852282

Git 的origin和master分析 push/diff/head相关推荐

  1. Git 的origin和master解析

    首先要明确一点,对git的操作是围绕3个大的步骤来展开的(其实几乎所有的SCM都是这样) 1.     从git取数据(git clone) 2.     改动代码 3.     将改动传回git(g ...

  2. Git上传代码报错Push rejected: Push to origin/master was rejected

    Git上传代码报错Push rejected: Push to origin/master was rejected 是因为你当前的项目中有和和历史不符的东西, 所以才被拒绝了 解决方案 git pu ...

  3. Git上传错误解决方案:Push rejected: Push to origin/master was rejected

    问题描述: 新建一个项目在IDEA中通过Git上传码云出现Push错误:Push rejected: Push to origin/master was rejected 试了网上的方法还是不行,出现 ...

  4. gitpull出错:error: failed to push some refs to/git pull origin master --allow-unrelated-histories

    今天上传远程仓库时出错 $ git push origin master To gitee.com:likepnd/recommendation_platform.git! [rejected] ma ...

  5. git学习:关于origin和master,自己增加一部分

    git的服务器端(remote)端包含多个repository,每个repository可以理解为一个项目.而每个repository下有多个branch."origin"就是指向 ...

  6. git的origin/master和origin master

    如有错误还请指出,感谢! origin master 其实由两部分组成,可以看作是两样东西origin和master. origin/master其实只有一部分,可以看做是一样东西. 对三样东西进行分 ...

  7. git远程操作报错git branch --set-upstream-to=origin/branch master

    报错信息如下 There is no tracking information for the current branch. Please specify which branch you want ...

  8. git 配置origin_git中各种命令中的origin和master如何理解和操作?

    git的服务器端(remote)端包含多个repository,每个repository可以理解为一个项目(远程仓库).而每个repository(远程仓库.远程项目)下有多个branch(分支). ...

  9. git pull origin master与git pull --rebase origin master的区别

    建议:最好看一遍廖雪峰的git教程,看完时间差不多就两个小时,git相关的知识写的很清楚,看完整个人都豁然开朗,很多git的问题都想通了. 区别: git pull=git fetch + git m ...

最新文章

  1. webpack学习笔记1
  2. java 继承 extends_java中的继承 (extends) 详解
  3. phoenixframework 自动化测试平台 1.4.8 版本发布
  4. keepalived做nginx的高可用,企业版简单介绍。
  5. 和包支付的钱哪里来_老瓦发问国际乒联:道理我都懂!问题钱从哪里来?
  6. Mac OSX x86 10.4.6 安装小记(1)
  7. 【Python实战项目】做一个 刮刮乐 案例,一不小心....着实惊艳到我了。
  8. 哈工大c语言作业,哈工大c语言-练习题
  9. C语言常用的数学函数
  10. 本科毕设-基于C8051单片机的身份识别系统设计
  11. 智慧城市智能化建设发展现状及展望
  12. 迁移学习,DomainAdaption 笔记
  13. js 手机号码和电话号码(座机号)正则校验
  14. mysql在结果中添加总计一行_在MySQL结果的最后一行获取总计?
  15. MacOS 系统 文件夹解析
  16. 查看oracle负载过大的原因,Oracle备份时系统负载过高导致ORA-3136错误和AIX系统的3D32B80D错误...
  17. XCTF simple-unpacked
  18. vue中的@代表什么
  19. (My)SQL 使用入门
  20. 【3D目标检测】[看code] VoxelRCNN RPN(一)

热门文章

  1. 【数据分析】脑图简介数据处理
  2. 解决 mac ssh空闲 连接断开问题
  3. vue学习笔记(四)- cmd无法识别vue命令解决方法
  4. Java中如何使用匿名内部类?
  5. 在同一窗口和同一选项卡中打开URL
  6. 使用jQuery在AJAX请求中添加标头
  7. 如何取消选中单选按钮?
  8. 为特定的提交生成一个git补丁
  9. Win10电脑系统文件损坏怎么修复
  10. ros开发增加clion常用模板及初始化配置(五)