- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
有人可以提供一种清晰、简单的方法来使用 Git 交换 2 个分支上的名称,并将 Github 作为远程存储库吗?
场景如下:
我在这方面还很陌生,我已经阅读了一些可视化的 Git 教程并搜索了这个网站和谷歌,但我仍然不清楚在 Git 中修复这个问题的最佳或预期方法(尤其是 -使用 Github 远程仓库)
我已经尝试了一些方法,但弄得一团糟——使用 Git 扩展重命名本地分支,但无法让远程 Github 存储库反射(reflect)该更改。我尝试创建新的分支,但不能总是让它们同时反射(reflect)在本地和远程(无论我在哪里创建它们)。
我终于能够通过 Git Extensions main pull 函数和“Prune remote branches”获得我需要的一切,它似乎使用 fetch 和 --prune - 这将远程删除反射(reflect)回本地,以及启用了一些强制/删除选项的push 功能。
一开始我想我可能只能重置/移动两个分支(即将 exp 移至 dev,然后将 exp 重置回 dev 所在的提交(返回 2),但是当尝试在 Git Extensions 中重置时,它要求我选择软重置、混合重置或硬重置——这让我停下来走另一条路,尝试重命名/创建新分支等。也许这是正确的轨道——如果是这样,我应该做一个软重置或硬重置 - 或者在提交任何打开的更改后都不重要?我对此进行了大量搜索,甚至了解工作目录、索引和分支,但在我的情况下仍然不清楚。
必须有更好的方法来完成这项工作 - 我如何轻松地交换两个分支(或重命名 2 个分支以便它们有效地交换),以一种所有更改都在本地和远程(在 Github 上)反射(reflect)的方式?
如果您能深入了解为什么您的方法是正确或最简单的方法,我将不胜感激。谢谢!
注意:我确实找到了this question关于重命名 master(或任何分支)——但是那里有很多步骤。我可以这样做两次,但我很难相信这是最好的方法。
最佳答案
分别从exp
和dev
创建两个新分支exp2
,dev2
。
$ git checkout exp
$ git branch exp2 # create new branch 'exp2' from 'exp'
$ git checkout dev
$ git checkout -b dev2 # create and checkout to `dev2` branch
删除本地和远程的 dev
和 exp
分支。
$ git branch -D dev # delete local 'dev' branch
$ git push origin :dev # delete remote 'dev' branch
$ git branch -D exp # delete local 'exp' branch
$ git push origin :exp # delete remote 'exp' branch
从 dev2
创建一个新的本地分支 exp
并推送到远程。
# make sure you are in 'dev2' branch
$ git checkout -b exp
$ git push origin exp
从 exp2
创建一个新的本地分支 dev
并推送到远程。
$ git checkout exp2 # checkout to 'exp2' so, current branch is 'exp2'
$ git checkout -b dev # create new branch 'dev'
$ git push origin dev # push 'dev' branch to remote
现在,如果一切正常,则删除本地 exp2
和 dev2
分支。 (可选)
$ git branch -D dev2 # delete local 'dev2' branch
$ git branch -D exp2 # delete local 'exp2' branch
关于Git:如何交换本地和远程的 2 个分支 (Github),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45539209/
我在理解这些函数如何更新底层引用、原子等时遇到问题。 文档说:(应用当前身份值参数) (def one (atom 0)) (swap! one inc) ;; => 1 所以我想知道它是如何“扩展到
尝试让一段代码看起来更好。 我在 Clojurescript 中有以下内容: (swap! app-state assoc-in [:lastresults] []) (swap! app-state
我在数据库中有带有排序顺序号的记录。现在我想创建一个带有向上和向下按钮的用户界面来重新排序它们。制作两个 functionsUp(record) 和 functionDown(record) 的最佳算
如何才能让第二次点击时返回?我想我必须以某种方式找到活跃的,但不确定。 $("#test").click(function(){ $("#dsa").fadeOut() $("#asd
我需要有关这次考试的帮助。我需要反转输入字符串。 int main(void) { char str[30]; int strlen; int i=0; int count=0;int
我正在用 C 语言玩指针...我尝试编写一个接收指向值的指针、检索指针的指针并交换指向值的指针的交换,而不是接收指向值的指针和交换值的常规交换。 这是代码... 互换功能: void swap(voi
如何在 javascript 中切换值?例如,如果 x = apple,则函数应返回 x = orange。如果 x = orange,则函数应返回 x = apple。不确定,这里有什么用,切换或交
刚接触这类东西,可能做错了什么,但是- 我有 3 个成员 std::unique_ptr currentWeapon; std::unique_ptr weaponSlotOne; std::uniq
我想在 Map 内的不可变列表内交换项目,示例: const Map = Immutable.fromJS({ name:'lolo', ids:[3,4,5] }); 我正在尝试使用
我创建了动态数组。如果具有某些值,则填充。打印它。但是交换/交换指针后(任务是在特定条件下交换行) 条件取决于sumL。为了不浪费您的时间,我没有描述细节。 问题在于交换指针。 for ( k = 0
要反转整个 vector,存在 std::reverse。但我想将一个 vector “划分”为两部分(恰好在中间)并将两者反转,将它们放回一起并再次反转整个 vector 。例如我们有: 0 1 2
我正在致力于代码最小化和增强。我的问题是:是否可以在不破坏代码逻辑的情况下交换上面的 if 语句? int c1 = Integer.parseInt(args[0]) ; int c
我读过释放 vector 内存的最佳方法是: vector().swap(my_vector); 而且我真的不明白发生了什么。交换函数需要 2 个 vector 并交换它们的元素,例如: vector
我正在尝试编写一个 Haskell 函数,该函数接受一串字母对,并在所有字母组成的字符串中交换该对字母,但我想出的方法感觉很尴尬且不惯用。 我有 swap a b = map (\x-> if x =
我正在尝试使用向上和向下箭头交换两个元素。 JSFiddle 解决方案会很棒! 我的 HTML: Some text down Some ot
当将 subview 与另一个太阳 View 交换时,是否需要重新应用约束?是否需要删除适用于已删除 View 的约束? 或者它们应该自动持续存在? 最佳答案 约束是 View 的“一部分”。当您删除
所以我制作网站已经有一段时间了,但只是真正用于显示和信息的东西。我想尝试一下 AngularJs,所以我遵循了 Codeschool 上的指南。当我根据在线文档意识到我使用的语法不被推荐时,我在该应用
我正在尝试编写一个函数,可以将字符串中的 unicode 字符替换为非 unicode ASCII 字符,问题是上传包含它们的字符串时,unicode 连字符和引号不会被读取。 我希望该函数有一个带有
我目前正在使用 Azure 网站来部署我的应用程序。我目前正在使用两个网站,每个网站监听我的 GIT 的不同分支。如图所示here . 现在,为了让它变得完美,我只是缺少一种在这两个实例之间快速切换的
在我的 javascript 中,有两个包含一些值的 div。 我想交换这些div中的值。 有什么解决办法吗? 最佳答案 var temp = $('#div1').html(); $('#div1'
我是一名优秀的程序员,十分优秀!