vs版本:vs2022
天天都在使用git,听说过变基这个名词,但是并没有实操过变基,正好今天有个同事说起一件事情:提交代码的时候有太多的自动合并,如果需要回退版本,操作起来很困难,理想状态下,应该就只有一条时间线,见下图,以前写了代码提交后,git会自动合并,导致有很多的分叉线,2023/5/4 13:30以前的部分,理想状态应该像2023/5/4 13:30以后的部分,不管多少人提交多少分支,左侧应该只有一条时间线。
这篇文章是教大家怎么使用vs的可视化界面操作,不涉及git命令。
先科普几个基本概念:
提取:获取最新代码到远程仓库,并未同步到本地仓库。
拉取:获取代码到本地仓库。
提交:把本地修改代码提交到本地仓库。
推送:把本地修改的代码提交到远程仓库。
同步:先拉取然后推送。
暂存:单独操作,比如修改了A、B两个文件,只想提交一个A文件,把A文件暂存,然后点“提交临时数据并推送”,可单独把A文件推送到远程,B文件保持未提交的修改状态。
储藏:(暂时未用过,暂不深究)。
至于变基的基本概念这里就不说了,请看这篇文章:两条命令让你的git轻松自动变基,学到了! - 码农教程
现在假设dev分支为基本分支,test1、test2是在dev延伸出来的两个分支,test1、test2代码改完后,要合并到dev分支。
如上图,dev版本上最新的是test1提交的代码,现在如果test2修改了代码,并合并到dev,必定会产生合并代码,并且左侧多出来一条时间线,如果不想多出来一条时间线,这个时候就需要使用变基。以下介绍具体步骤。
第一步 获取最新代码
切换到test2分支,把dev的代码合并到当前分支,并推送,使当前代码为最新代码;(怎么把dev合并到当前分支:如下如,右键dev分支,点击“合并到Current Branch”,弹出“确定要将dev合并到test2?”,点是即可,然后点推送)
现在test2已经是最新代码
第二步 提交分支
修改test2分支上的代码, 全部提交,但是不推送(相当于保存到本地)
切记不要推送到远端,下图说明,代码还在本地。
第三步 变基
保持在当前分支下test2,将当前分支变基到dev;
具体操作步骤:点击分支下拉框,右键dev,点击“将Current Branch的基准重定到”,见下图
确定要将test2变基到dev? 选择是
第四步 推送
推送当前分支到远程
第五步 合并分支
切换到dev分支,把test2合并到dev分支,推送,至此,变基合并完成
最终结果如下图
最后的最后,把思路理一下,
首先,要保持分支为最新代码,把主线上的代码合并到当前分支上,使当前分支为最新,把修改的代码提交到本地,切记不要提交到远程,提交到远程就无法变基了,接下来就是变基了,使本地保持最新代码,把分支代码变基,变基完成,这个时候在推送,就把分支代码变基到最后修改的位置,并推送到远程,最后一步,把分支代码合并到主线。
实际的操作步骤不一定按照我上面说的走,上面的步骤在当前条件下满足要求;但核心思路就是:把主线的最新代码合并到分支,分支进行变基,推送,再把分支代码合并到主线。