git 的基本操作 Master and branch的版本合并 @ VS 1019

前言:

在VS 2019有git 的可视化管理,但,感觉微软其实就是在git上包了一层。版本冲突后,还是要靠git 的命令行代码搞。本文记录了一次,branch和master的版本合并的过程。作为,后续的参考。

【注意,这个是一个本地版本的例子】


1 版本情况:

1 查看本地版本:

git status

 

确认在分支版本上, 

可以用

git log

 

 看一下,现在是在HEAD -> Branch.... 分支上面,

分支版本的情况,并确认分支版本的版本ID,cbef9b7b6eb8658ee7a96f12c61c5957e99316e1

1.1 看主支版本:

git log master

 

并获取,准备合并的主支版本的ID , 71ee9e4af6a7e2052281a114b73396fb1f2dde5b


2 CHECK OUT 主支版本:

git checkout master

提示从分支到主支版本的改变, 

 用git log 确认一下,主支版本情况

确认我们在主支版本上了,

然后, 最好用

git reflog

 查一下所有,支的版本,主,分支,包括,已经删除的支的版本,


3 Merge

选定上面显示的分支版本ID,进行Merge

$ git merge cbef9b7

Performing inexact rename detection: 100% (585/585), done.
Performing inexact rename detection: 100% (595/595), done.
。。。。。。
CONFLICT (content): Merge conflict in AAMED.dir/Debug/AAMED.log
Automatic merge failed; fix conflicts and then commit the result.
【发现冲突文件】

注意,执行后,在主支上,命令行会显示,你现在是正在合并版本的状态:蓝色的字体,MERGING


 4 解决冲突:为了标识颜色的信息,这里截图:

4.1 很乱的各种冲突信息:

【案】其实我们只需要解决绿框里面两个源码冲突,其他的都不是我们要的。


4.2 先把关系的变更给交到提交列表:

在红区的两个CPP文件,是我们真正要提交的源码:

我们先在编码的VS 2019IDE里面打开这两个文件:会发现,GIT已经自动将Master 和 Branch的版本比较,冲突标记加到对应的源码的上下文里面了:

<<<<<<< HEAD

这是主分支中的内容 (Master)

=======

这是要合并的分支中的内容 (Branch)

>>>>>>>

要合并的分支

由于我们是把Branch Merge 到 Master,

所以,Master的原来的东西,要被Branch给替换掉,也就是

这段信息的意义:

<<<<<<< HEAD

这是主分支中的内容 (Master) 这里面的内容要被替换掉

=======

这是要合并的分支中的内容 (Branch) 这里面的内容要保留

>>>>>>>

不过,具体也要看你的应用情况,你需要自己做出判断,反正,要决定哪些保留,哪些删除,然后,去掉

 <<<<<<< HEAD

=======

>>>>>>>

这些辅助线,你的源码就改完了,可以存一下。

然后,我们要做的,就是把解决好的冲突的文件,加到要提交的列表里面:

git add
$ git add src/main.cpp
$ git add src/FLED_drawAndWriteFunctions.cpp

 加好后,用git status 看一下,是否在绿区:

OK ,在绿区了,但是,绿区有一堆,我都不想管的文件log啥的,要去掉,

现在要去掉不行进行版本管理的文件,有两个步骤:

步骤1 ,如果要长久的去掉这个文件,以后都不要管了:

那要通过在.gitignore文件中添加相应,在项目的版本控制路径下面,就是当前你操作的目录路径即可:

vim .gitignore

就可以打开相关的配置文件了,然后,想屏蔽哪个文件,哪类文件,直接写在里面的规则来实现

# 例如,所有的log文件
*.log
# 例如,目录Debug
/Debug# 忽略所有文件
*
# 但不忽略.cpp文件
!*.cpp
# 也不忽略.gitignore和README.md文件
!.gitignore
!README.md

 步骤2 ,就是当前的绿区的文件:

用命令:

git reset 

比如,绿区也就是等待提交区,有一堆tlog的文件:

我们执行,

$ git reset HEAD *.tlog

再用git log查看,就有:

这样tlog的文件都去掉,然后,类似的方法去掉所有的绿区不需要提交的文件。


 现在绿区OK了,但是,红区还有文件

先处理: Unmerged paths 文件:

“both modified”意味着在当前分支和要合并的分支中对这些文件都有修改,并且这些冲突还没有被解决。
而且,由于这些文件已经进入和红区(也就是暂存区)(staged)了
通过上面的.gitignore 文件,已经来不及了

git reset HEAD 

 我们通过,上面的命令来取消这些暂存区的文件,红区文件

git reset HEAD -- AAMED.dir/Debug/*.obj 

 执行后,我们看到Staged的红区文件里面obj的文件就被拿掉了,

同样方法,我们拿到所有我们不想进行版本控制的,已经进入暂存区的文件:


接下来,我们来处理,连staged都没进去的问题
 Changes not staged for commit:

Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git restore <file>..." to discard changes in working directory)
        modified:   .gitignore
        modified:   AAMED.dir/Debug/AAMED.log
        modified:   AAMED.sln
        modified:   AAMEDemo.dir/Debug/AAMEDemo.Build.CppClean.log
        modified:   AAMEDemo.dir/Debug/AAMEDemo.ilk
        modified:   AAMEDemo.dir/Debug/AAMEDemo.log
        modified:   AAMEDemo.dir/Debug/AAMEDemo.tlog/CL.command.1.tlog
        modified:   AAMEDemo.dir/Debug/AAMEDemo.tlog/CL.read.1.tlog
        modified:   AAMEDemo.dir/Debug/AAMEDemo.tlog/CL.write.1.tlog
        modified:   AAMEDemo.dir/Debug/AAMEDemo.tlog/link.read.1.tlog
        modified:   AAMEDemo.dir/Debug/AAMEDemo.tlog/link.write.1.tlog
        modified:   AAMEDemo.dir/Debug/Contours.obj
        modified:   AAMEDemo.dir/Debug/EllipseNonMaximumSuppression.obj
        modified:   AAMEDemo.dir/Debug/FLED.obj
        modified:   AAMEDemo.dir/Debug/FLED_Initialization.obj
        modified:   AAMEDemo.dir/Debug/FLED_PrivateFunctions.obj
        modified:   AAMEDemo.dir/Debug/FLED_drawAndWriteFunctions.obj
        modified:   AAMEDemo.dir/Debug/Group.obj
        modified:   AAMEDemo.dir/Debug/LinkMatrix.obj
        modified:   AAMEDemo.dir/Debug/Node_FC.obj
        modified:   AAMEDemo.dir/Debug/Segmentation.obj
        modified:   AAMEDemo.dir/Debug/Validation.obj
        modified:   AAMEDemo.dir/Debug/adaptApproxPolyDP.obj
        modified:   AAMEDemo.dir/Debug/adaptApproximateContours.obj
        modified:   AAMEDemo.dir/Debug/main.obj
        modified:   AAMEDemo.dir/Debug/vc142.pdb
        modified:   ALL_BUILD.vcxproj
 

 

 用下面的命令来处理:

git restore

例如,去掉 AAMEDemo.dir/ 下的所有的文件

$ git restore  AAMEDemo.dir/*.*

最暴力的方法是:全部都不管了啊

$ git restore *

 


现在就剩下:

Untracked files:
这是本来就没有版本控制的文件,我们可以不理他就好了。这样,提交的暂存区(绿区)就剩下我们要提交的文件了。


5 提交:

利用以下命令:

git commit

然后,可以加上注解,例如:

$ git commit -m "now we merge the master and branch toghter before modify for EXE merge into C#"

git status 

我们看到,已经回到master,然后,该处理的文件都处理好了,就剩下本来没有加入版本管理的文件:


6 最后,看版本merge的情况

用git log命令,这时候,可以看到master和branch的情况,这样就完成了版本的合并工作:


最后,我们看一下VS 2019的git中的结果:

在VS 2019的git IDE的窗口里面

现在可以看到branch和master主,分支的版本。

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

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

相关文章

【二进制部署k8s-1.29.4】十三、metrics-server的安装部署

文章目录 简介 一.metrics-server的安装 简介 本章节主要讲解metrics-server的安装&#xff0c;metrics-server主要是用于采集k8s中节点和pod的内存和cpu指标&#xff0c;在观察几点和pod的实时资源使用情况还是比较有用的&#xff0c;如果需要记录历史信息&#xff0c;建议采用…

运行编译openjdk12-33

编译环境 ubuntu20 Ubuntu里用户可以自行选择安装GCC或CLang来进行编译&#xff0c;但必须确保最低的版本为GCC 4.8或者CLang 3.2以上&#xff0c;官方推荐使用GCC 7.8或者CLang 9.1来完成编译。 源码 https://github.com/openjdk/jdk/tree/jdk-12%2B33 安装gcc sudo apt…

人工智能的未来发展前景:机遇与挑战

人工智能&#xff08;AI&#xff09;的发展在过去的几十年里取得了突飞猛进的成就&#xff0c;已经成为推动全球科技创新的关键动力之一。随着技术的不断进步和应用的日益广泛&#xff0c;AI的未来发展前景显得更加广阔&#xff0c;同时也面临一系列新的机遇和挑战。 技术革新…

使用neural_network_console训练模型并导出.nnb文件应用于索尼spresense

一.创建数据集 首先你需要一个csv标记的数据集 然后我们使用neural_network_console将数据集进行处理 dataset->create dataset->image 用户可以通过该界面选择源目录&#xff08;Source Dir&#xff09;&#xff0c;输出目录&#xff08;Output Dir&#xff09;&…

哈希表、HashMap\Map-1657. 确定两个字符串是否接近

题目链接及描述 1657. 确定两个字符串是否接近 - 力扣&#xff08;LeetCode&#xff09; 题目分析 今日看到这道题目&#xff0c;乍一看觉得非常熟悉&#xff0c;对于将一个字符串转换为另一个字符串的题目之前做过一些。分析题目&#xff0c;题目中所述就是两种操作&#xff…

ubuntu蓝牙连接问题

ubuntu蓝牙连接问题 ubuntu蓝牙连接问题1、安装驱动2、优化蓝牙配置文件3、解决 Failed to connect: org.bluez.Error.Failed ubuntu蓝牙连接问题 之前我发现电脑有蓝牙图标&#xff0c;且能打开关闭&#xff0c;就以为蓝牙默认已经配置好了&#xff0c;直到有一天我尝试连接我…

嵌入式软件跳槽求指导?

嵌入式软件行业的跳槽确实需要一些特定的策略和技巧。我这里有一套嵌入式入门教程&#xff0c;不仅包含了详细的视频讲解&#xff0c;项目实战。如果你渴望学习嵌入式&#xff0c;不妨点个关注&#xff0c;给个评论222&#xff0c;私信22&#xff0c;我在后台发给你。 因为这个…

【设计模式】装饰器模式(结构型)⭐⭐

文章目录 1.概念1.1 什么是装饰器模式1.2 优点与缺点 2.实现方式3. Java 哪些地方用到了装饰器模式4. Spring 哪些地方用到了装饰器模式 1.概念 1.1 什么是装饰器模式 它允许用户在不修改现有对象的代码的情况下向对象添加新的功能&#xff1b;这种模式是通过创建一个包含该对…

前端面试题日常练-day53 【面试题】

题目 希望这些选择题能够帮助您进行前端面试的准备&#xff0c;答案在文末 1. 在PHP中&#xff0c;以下哪个函数可以用于从一个数组的末尾删除一个元素并返回被删除的元素&#xff1f; a) array_pop() b) array_push() c) array_shift() d) array_unshift() 2. 在PHP中&…

列存在 OceanBase 数据库架构中的应用与演进

OceanBase 4.3 版本上线了列存功能&#xff0c;以满足实时分析的需求。 本文作为《特性解读&#xff1a;列存技术》的后续&#xff0c;将详细阐述列存技术在OceanBase数据库架构中的应用、发展历程&#xff0c;以及未来的趋势。 一、前言 1970 年&#xff0c;关系模型之父 Co…

LeakSearch:针对网络公开凭证的安全扫描与检测工具

关于LeakSearch 在红队演戏过程中&#xff0c;往往需要获取到针对目标域的访问权限。在这个过程中&#xff0c;很多红队人员会选择使用暴露在互联网上的代理服务器来实现目标域的访问&#xff0c;那么此时就需要在互联网上收集公开暴露的凭证信息。 对于蓝队来说&#xff0c;…

Playwright+Python+Pytest:基础方法二次封装简化及链式调用

引言 随着Web应用的日益复杂化&#xff0c;自动化测试成为了确保软件质量的关键环节。Playwright 是一个强大的自动化库&#xff0c;它支持在 Chromium、Firefox 和 WebKit 中运行自动化脚本。本文将介绍如何使用 Playwright 的 Python 同步 API 来简化点击和填充操作&#xf…

阿里云邮件推送配置教程:API配置的步骤?

阿里云邮件推送服务如何使用&#xff1f;如何配置邮件推送服务&#xff1f; 阿里云提供了强大的邮件推送服务&#xff0c;帮助企业高效地发送邮件通知、验证码、营销活动等。Aok将详细介绍阿里云邮件推送的配置教程&#xff0c;以及API配置的步骤&#xff0c;同时简要提及AokS…

数据流图要点和难点实际应用

数据流图(Data Flow Diagram,DFD)是一种图形化表示信息系统中数据流动和处理的方式。它主要用于描述系统如何接收输入数据,经过一系列的处理步骤,然后产生输出数据。数据流图在系统设计阶段特别有用,因为它可以帮助开发人员、业务分析师和其他利益相关者更好地理解系统的…

Python字符串数据类型之字符串

四、Python数据类型 4.1、Python内置数据类型 整型&#xff1a;int浮点型&#xff1a;float布尔类型&#xff1a;bool字符串&#xff1a;str二进制类型&#xff1a;bytes、bytearray复数&#xff1a;complex列表&#xff1a;list元组&#xff1a;tuple字典&#xff1a;dict a…

C#WPF控件Textbox绑定浮点型数据限制小数位方法

本文讲解C#WPF控件Textbox绑定浮点型数据限制小数位方法。 XAML中,使用StringFormat来格式化TextBox的文本 <Window x:Class="WpfApp.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.m…

【使用 uiautomator2 脚本进行波点音乐app自动化操作的教程】

本教程将指导您使用 uiautomator2 库编写脚本&#xff0c;实现自动化操作。如果您需要在设备断开连接或出现异常时重新连接设备并继续执行任务&#xff0c;这里有一份详细的代码示例和使用说明。 环境准备 安装 Python&#xff1a; 确保您的系统上安装了 Python&#xff08;推…

[数据集][目标检测]盲道检测数据集VOC+YOLO格式2173张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;2173 标注数量(xml文件个数)&#xff1a;2173 标注数量(txt文件个数)&#xff1a;2173 标注…

基于R语言BIOMOD2 及机器学习方法的物种分布模拟与案例分析实践技术

BIOMOD2是一个R软件包&#xff0c;用于构建和评估物种分布模型&#xff08;SDMs&#xff09;。它集成了多种统计和机器学习方法&#xff0c;如GLM、GAM、SVM等&#xff0c;允许用户预测和分析物种在不同环境条件下的地理分布。通过这种方式&#xff0c;BIOMOD帮助研究者评估气候…

常用接口测试及接口抓包常用的测试工具

一、常用抓包工具 01、F12 Web端的话&#xff0c;google浏览器直接F12开发者模式 点击network进行抓包分析。 02、Fiddler抓包工具 客户端和服务端的http代理&#xff0c;客户端所有的请求都要先经过Fiddler&#xff0c;到响应的服务端&#xff0c;然后端返回的所有数据也都…