Git分支操作与远程仓库的使用

Git分支操作

  • 本地仓库
    • 创建分支
    • 合并分支
    • 删除分支
  • 远程仓库
    • push 推送远程分支
    • pull 拉取远程分支
    • fetch 更新远程分支
    • 本地分支与远程分支的跟踪关系

本地仓库

由于Git的分布式特性,所以没有绝对的本地和远程概念,一切都是相对的。对于分支的操作,个人认为其实重点在于本地的分支操作,而对于远程仓库的分支操作归结起来只有 推送拉取

创建分支

创建本地分支有两种命令方式,第一是使用分支命令branch,第二是使用查看命令checkout

推荐使用查看命令 :git checkout -b <new_branch_name>,它是下面两条命令的简写

git branch <new_branch_name>
git checkout <new_branch_name>

深度应用,在某个场景下,当我们的项目在不断推进后,老板突然说:“第一版其实还不错,我们再看一下”,我:“…”。

这时我们当然可以使用回滚或者查看历史版本的方式,在这之前先备份一下当前代码,又或者创建个分支保护一下什么的,但是这样做仍然可能会很危险,亦或者很麻烦,这个时候我们就会想,如果能在第一版有个分支就好了。是的,我们还可以根据某个历史提交状态来创建一个分支。

仍然使用查看命令git checkout -b <branch_name> <SHA-1>,使用历史提交版本的SHA-1校验和来创建指定历史版本的分支,SHA-1校验和的值可以通过git log查看,它实际上也是多个命令的简写

git checkout <SHA-1>
git branch <branch_name>
git checkout <branch_name>

git checkout -b甚至可以根据远程仓库来创建本地分支,git checkout -b <local_branch> <remote>/<remote_branch>

说明:git branch会根据当前的代码状态创建分支,不管这个状态是最终状态还是某个历史状态,git checkout 查看 / 切换分支,也可以查看某个历史版本

除此之外,还能使用git checkout --orphan <branch_name>创建一个空白分支

命令总结

  • git checkout -b <branch_name> 创建分支
  • git checkout -b <branch_name> <SHA-1> 在历史版本SHA-1位置创建分支
  • git checkout -b <branch_name> <remote>/<remote_branch> 基于远程分支创建分支
  • git checkout --orphan <branch_name> 创建空白分支

合并分支

git提供了两种合并指令 mergerebase,用于将两个或两个以上的开发历史加入(合并)一起。如果合并没有冲突,则会自动进行一次提交。

git merge <branch_name>,将 branch_name 分支合并到当前分支

删除分支

  • 使用git branch -d <branch_name>来删除指定分支,及时的删除一些无用分支是个良好的习惯,不然我们将在众多分支中晕头转向。
  • 使用git remote prune <remote> 来清除本地缓存的无效远程分支指针

远程仓库

实际上并不存在显性的对远程分支的操作,所有对远程分支的操作都是 push 的副作用。

对远程仓库的操作一般时 fetch,pull 和 push,这个操作的意义在于同步远程仓库和本地仓库,更确切的说法是将本地仓库的某条分支和远程仓库的某条分支进行同步

比如本地仓库有 mastertest 两条分支,远程仓库有 masterdevelop 两条分支,我们可以将远程仓库的 develop 分支同步到本地的 master 分支上,也可以将本地的 master 分支同步到远程仓库的 master 分支上,同步的实质时合并两条分支,如果是两条不相关的分支,则不能合并,即推送 / 拉取不成功(强行推送 / 拉取除外)。

push 推送远程分支

push的完整写法是:

git push <remote> <local_branch>:<remote_branch>

意思是将本地 local_branch 分支推送到远程仓库的 remote_branch 分支,并进行 merge 合并,如果远程仓库没有 remote_branch 分支则会创建分支,所以在远程分支不存在的情况下,该操作相当于创建远程分支

  • 省略远程分支名 git push <remote> <local_branch> ,git会推送local_branch分支到远程仓库的与本地分支同名的远程分支
    eg:git push origin dev 相当于 git push origin dev:dev 的简写

  • 省略本地分支名 git push <remote> :<remote_branch> ,Git会删除远程仓库上的remote_branch分支,即用一个空分支更新remote_branch分支,相当于删除远程分支
    eg:git push origin :dev 相当于 git push origin --delete dev

  • 省略所有分支名 git push <remote> ,如果当前分支和远程分支存在追踪关系,则本地分支和远程分支都可以忽略。如果当前分支只有一个远程主机,那么远程主机也可以省略。

  • git push --all <remote> 将本地的所有分支都推送到远程主机。

  • git push --force <remote> [<local_branch>:<remote_branch>] 当服务器上版本和本地版本不一致时,push会发生冲突,git会提示我们先使用pull来解决冲突,如果一定要推送,可以使用这个命令,除非一定要这样,否则应该避免使用force。

pull 拉取远程分支

和push类似,pull的完整写法是(注意本地分支和远程分支的顺序):

git pull <remote> <remote_branch>:<loacl_branch>

意思是将远程仓库 remote_branch 分支拉取到本地仓库的 local_branch 分支,并进行merge合并,如果本地仓库没有 local_branch 分支则会创建分支。

  • 省略本地分支名 git pull <remote> <remote_branch> ,git会拉取remote_branch分支当前本地分支

  • 省略所有分支名 git pull <remote> ,如果当前分支和远程分支存在追踪关系,则本地分支和远程分支都可以忽略。如果当前分支只有一个远程主机,那么远程主机也可以省略。

  • git pull <remote> --rebase 合并的时候采用rebase模式

fetch 更新远程分支

git pull 实际上是 git fetchgit merge 的联合操作

git pull origin master

相当于

git fetch origin master
git merge origin/master

本地分支与远程分支的跟踪关系

  • git branch -vv 查看分支跟踪情况
  • git branch --set-upstream-to=<remote>/<branch_name> <branch_name> 将branch_name分支追踪远程分支remote/branch_name
  • git branch -u <remote>/<branch_name> 设置当前分支追踪远程分支 remote/branch_name

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/281331.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SimMechanics/Second Generation倒立摆模型建立及初步仿真学习

笔者最近捣鼓Simulink&#xff0c;发现MATLAB的仿真模块真的十分强大&#xff0c;以前只是在命令窗口敲点代码&#xff0c;直到不小心敲入simulink&#xff0c;就一发不可收拾。话说simulink的模块化建模确实方便&#xff0c;只要拖拽框框然后双击设置属性就可以慢慢堆建自己的…

10 行代码提取复杂 Excel 数据

把 Excel 文件导入关系数据库是数据分析业务中经常要做的事情&#xff0c;但许多 Excel 文件的格式并不规整&#xff0c;需要事先将其中的数据结构化后再用 SQL 语句写入数据库。而一般情况下&#xff0c;结构化的工作量会比较大&#xff0c;而且很难通用&#xff0c;每次都要针…

将一个数组拆分为若干个相等数组

var a [法国,澳大利亚,智利,新西兰,西班牙,加拿大,阿根廷,美国,0,国产,波多黎各,英国,比利时,德国,意大利,意大利]; var b []; var result []; var k 0; for(var i 0; i<a.length; i){ if(i%3 0){ b []; for(var j 0; j<3; j){ if(a[ij] undefined){ continue; …

人工智能模型的网络结构可视化

本文主要介绍人工智能模型的网络结构可视化的常见方法。对于使用神经网络模型来说&#xff0c;我们主要关注的是模型的输入和输出。在 ML.NET 中使用 ONNX 模型时&#xff0c;我们就需要了解这些信息&#xff0c;以便在构成神经网络的所有层之间生成连接映射。下图就是昨天 《Y…

Git 撤销操作 / 回滚历史

撤销操作 git checkout -- <filename>&#xff0c;放弃文件的当前更改&#xff0c;回到最近一次的提交状态git reset HEAD <filename>&#xff0c;取消暂存文件git commit --amend&#xff0c;覆盖上一次的提交&#xff0c;虽然不是撤销操作&#xff0c;但有类似的…

整理ASP.NET MVC 5各种错误请求[401,403,404,500]的拦截及自定义页面处理实例

http://2sharings.com/2015/asp-net-mvc-5-custom-404-500-error-hanlde https://blog.csdn.net/yhyhyhy/article/details/51003683 ASP.NET MVC 5的开发中&#xff0c;服务器的各种错误[如&#xff1a;401&#xff08;登录授权验证&#xff09;&#xff0c;403&#xff08;禁止…

url字符转义

作者在做短链接功能时&#xff0c;url参数里带了&字符&#xff0c;结果无法转换。后来查了一下&#xff0c;发现可以用其它符号代替。下面是对应表 URL 中号表示空格 %2B 空格 URL中的空格可以用号或者编码 %20 / 分隔目…

编辑器领域正发生变革?从面试看 Visual Studio Code 的崛起

Visual Studio Code&#xff08;VS Code&#xff09;的使用率在迅速上升&#xff0c;现在已经成为大多数工程师的首选编辑器&#xff0c;并似乎正迅速抢占其他顶级编辑的市场份额。Triplebyte 每周都会面试数百名工程师。在每次面试中&#xff0c;我们都会记录面试者使用的编辑…

C#7.0 ref引用传递

1.概要在工作中大家用到引用类型是非常多的&#xff0c;大家都知道引用类型在使用过程中传递的是对象引用并不会发生整个对象复制。而值类型在传递的过程中就不一样了&#xff0c;我曾经在编写代码时希望通过值类型来压低应用程序的内存占用&#xff0c;在高并发的情况大量的对…

Vue+Axios同步请求

axios本身是没有同步请求的&#xff0c;要实现同步请求&#xff0c;用到的是ES7的async和await ES7的异步特性async / await async用于声明一个函数是异步的&#xff0c;await用于声明在一个异步函数中等待语句执行完毕。也就是说await只能在async函数中使用。简单示例如下&a…

关于vue执行打包后,如何在本地浏览问题

最近一个人在捣鼓vue&#xff0c;写完项目后发现在npm run dev下可以正常访问&#xff0c;bulid之后却一片空白&#xff0c;查看console出现许多Failed to load resource: net::ERR_FILE_NOT_FOUND。恩&#xff0c;看了下网上评论找到了正确的方法 webpack.prod.conf.js 中outp…

ELFhash

字符串哈希算法&#xff08;以ELFHash详解&#xff09; 更多字符串哈希算法请参考&#xff1a;http://blog.csdn.net/AlburtHoffman/article/details/19641123 先来了解一下何为哈希&#xff1a; 哈希表是根据设定的哈希函数H(key)和处理冲突方法将一组关键字映射到一个有限的地…

android面试详解

前台就是和用户交互的进程 可见进程例如一个activity被一个透明的对话框覆盖&#xff0c;该activity就是可见进程 服务&#xff1a;service进程 后台一个activity按了home按键就是从前台退回到后台 标准模式&#xff1a;不管任务栈是否存在相同的activity都会创建一个新的activ…

element-ui Notification重叠问题,原因及解决办法

在1个方法中调用两次this.$notify方法&#xff0c;会出现通知框重叠的问题 methods: {checkLogin: function () {if (this.username ) {this.$notify({title: 提示,message: 请输入用户名})}if (this.password ) {this.$notify({title: 提示,message: 请输入用户密码})}}}网上…

Visual Stiudio使用技巧

技巧1 自动生成带参构造函数当我们在编写代码时会经常遇到初始化一个的类&#xff0c;需要通过构造函数进行对象初始化。那么这个时候我们可能会需要逐个去手动写&#xff0c;这样的工作即重复又无趣。如果是在项目非常紧急的情况下还有大量的字段需要与入参一一对应起来简直太…

js将时间戳格式化为HH:ii:ss的格式

将时间戳格式化为 HH:ii:ss的格式 <html> <head> </head> <body><span id"time"></span><script>var timestamp Date.parse(new Date())/1000;var time_old Date.parse(new Date())/1000;timeAdd()/*** purpose : …

Struts 整合 SpringMVC

Struts 整合 SpringMVC 过程&#xff1a;这篇文章是我在整合过程中所做的记录和笔记 web.xml &#xff1a;筛选器机制过滤 原机制是拦截了所有 url &#xff0c;即 <url-pattern>/*</url-pattern>新机制为了将 structs2 的 url 与 SpringMVC 的 url 区分开来&#…

Vue保持用户登录及权限控制

vue-router-power-demo 核心内容有两点&#xff1a; 一是保持用户登录状态&#xff0c;二是根据登录用户的角色动态挂在路由 使用vuex保持用户登录 点击登录按钮&#xff0c;使用vuex的actions分发登录操作&#xff0c;发送用户名和密码到后台获取登录token&#xff0c; 并存…

java B2B2C Springcloud多租户电子商城系统-Spring Cloud Sleuth

在微服务框架中&#xff0c;一个由客户端发起的请求在后端系统中会经过多个不同的的服务节点调用来协同产生最后的请求结果&#xff0c;每一个前段请求都会形成一条复杂的分布式服务调用链路&#xff0c;链路中的任何一环出现高延时或错误都会引起整个请求最后的失败。 愿意了解…

C#性能测试BenchmarkDotnet

1.简介在我们开发高性能代码时&#xff0c;需要各种针对性能优化进行编码。那么如何才能知道我们所加的代码是否有性能方面的正向优化呢&#xff1f;有了BenchmarkDotNet&#xff0c;做性能对比测试就非常容易了&#xff0c;只需要把你的测试方法加上特性[Benchmark], 想做不同…