详解使用IDEA模拟git命令使用的常见场景

 更新时间:2021年5月1日 10:01  点击:2144

大家好,最近白泽第一次开始参与小组合作开发,以前都是自己用git保存自己的代码,自己维护,用git的场景也比较单一,没有遇到过拉取代码合并出现冲突的问题。但是小组开发拉取远程仓库的代码时,遇到他人所提交代码与自己的本地代码出现冲突在所难免,所以白泽特意去学习了一下git的冲突处理,接下来用一个小demo复现一下我学习的过程

前期准备

新建一个远程仓库

在一个文件夹内建立两个子文件夹作为两个本地仓库的存放位置

之所以建立两个文件夹,这样做的目的是为了模拟两个用户对同一个项目进行合作开发,假设demo1为用户A的本地仓库,demo2为用户B的本地仓库,后面会用两个本地仓库模拟多人开发中会遇到一些常见场景,并给出解决方案

在demo1文件夹中新建test1与test2两个文件作为demo1仓库的初始内容,此时demo2文件夹为空

本地仓库与远程仓库建立联系

下面这张图是新建git远程仓库成功之后显示的提示文档,指示你该如何将本地仓库与远程仓库建立联系,我给出了每条命令的解释

echo "# 内容" >> README.md 		  //生成一个帮助文档,可以不通过命令行创建,也可以不创建
git init							//将当前文件夹初始化为一个git本地仓库
git add README.md					//将README.md添加到暂存区
git commit -m "第一次提交"		//将暂存区中的文件提交到本地的git仓库
git branch -M main					//将当前分支重命名为main
git remote add origin git@github.com:BaiZe1998/git-idea-demo.git//添加远程仓库(建立联系)
git push -u origin main				//将本地仓库当前分支的内容推送到远程仓库的main分支,使用-u参数后以后推送如果不加origin main,就会默认推动到origin的main分支

此时依旧在git-idea-demo1的文件夹内,在下方的终端输入处输入上述所有的命令,结束之后结果应该与下图相同

细心的你发现远程仓库的内容确实更新了,但是有一个问题就是你发现远程库并没有test1.txt与test2.txt两个文本文件,原因在于上面我们使用了一个命令 git add README.md,这个命令只是将README.md这一个文件添加到缓存区,后面的 git commit -m "第一次提交" 负责将缓存区中内容全部提交到本地仓库,然后由git push -u origin main命令将本地仓库内容全部推送到远程仓库,为了使得我们远程仓库也能同步test1.txt与test2.txt必须一开始就将这两个文件加入本地的缓存区

接下来通过输入三行代码将test1.txt与test2.txt同步到远程仓库

git add .					//表示将当前文件夹内所有文件加入缓存区
git commit -m"描述信息"		 //提交时可以添加一些描述信息"
git push			//第一次使用了git push -u origin main之后下一次提交只需要git push简写即可

最后远程仓库也同步了本地仓库的数据,我们的准备工作也做好了,接下来正式开始模拟两个用户协同开发时会遇到的场景

模拟两个用户协同开发的场景(使用IDEA自带界面操作,不使用命令行)

假设:员工A是某公司的老员工,员工B是公司的新人

推送代码到远程仓库(当只有一个人在维护远程仓库时)

事实上上述操作git的步骤都是使用了git的命令行操作的方式,并没有发挥出IDEA的强大,接下来将尽量使用IDEA的界面上的可视化按键去完成对git的操作

  • 当员工B还未加入到员工A的开发小组,整个项目只有员工A在维护的时候,员工A在自己的新建了test3.txt,接下来将该文件添加到缓存区,并提交到本地仓库,然后再从本地仓库推送到远程仓库(修改->添加->提交->推送,这是很常见的一个git操作流程,注意接下来将不使用命令行操作)
  • 修改项目内容(添加了test3.txt)

添加到缓存区

提交到本地仓库,并且选择commit and push

远程仓库完成了数据的同步

克隆远程仓库项目

今天员工B被分配到员工A所在的小组参与开发,所以他首先要将小组当前正在开发的分支的项目代码从远程仓库克隆到本地,首先用IDEA打开git-idea-demo2文件夹,在终端Terminal处输入git clone 远程仓库的地址将整个项目拷贝到git-idea-demo2文件夹内

注意,虽然员工B在git-idea-demo2文件中用了克隆,但是git-idea-demo2中的git-idea-demo文件才是员工B本地仓库的存放文件(进入之后看到.git文件在哪个文件夹内,哪个文件夹就是本地仓库文件夹)

拉取远程仓库的代码(远程仓库与本地仓库无冲突)

  • 就在员工B开始正式参与A小组的开发,当前他还未对上一次克隆下来的版本的代码做任何修改,在准备开始编码前,他又尝试去远程仓库拉取最新的代码(因为员工A有可能又提交了新的修改的版本)
  • 为了满足情景,我们让员工A修改一下test3.txt,然后推送到远程仓库

员工B拉取远程仓库的最新版本的代码,选择第一个,将要修改的代码合并到当前分支

此时员工B本地仓库的main分支已经已经合并了员工A提交到远程仓库main分支上的修改(注意此时员工B,从远程仓库拉取代码,将代码合并到本地仓库,都是IDEA自动完成,这只有在没有冲突发生的情况下才能做到)

拉取远程仓库的代码(远程仓库与本地仓库有冲突)

员工B修改了test3的代码,并且执行添加->提交->推送

接下来员工A也修改了test3.txt文件,这次将原来的第一行内容改变(此时员工A还没有去拉取远程仓库的代码),然后在提交修改之前员工A又去拉取远程仓库的代码(提交自己的更改前拉取远程仓库代码是一个好的习惯)

发生了冲突,因为员工A本地所做的修改是在员工B推送到远程仓库的前一版本的基础上做的修改,而员工B的推送使得远程仓库的最新版本与员工A本地版本不同(很明显员工B修改了test3文件,而员工A本地也在修改test3文件,如果贸然将远程仓库的代码合并到员工A的本地,远程仓库的代码很有可能覆盖掉员工A当前所做的修改,所以此时需要手动处理冲突,选择最终需要保留的部分)

手动处理冲突,最终选择保留A自己的修改,以及额外又添加上了第三行修改

员工A将修改推送到远程仓库(本次整体的流程为:拉取->处理冲突(如果有)->添加->提交->推送)

到此这篇关于详解使用IDEA模拟git命令使用的常见场景的文章就介绍到这了,更多相关IDEA模拟git命令使用内容请搜索猪先飞以前的文章或继续浏览下面的相关文章希望大家以后多多支持猪先飞!

[!--infotagslink--]

相关文章

  • IntelliJ IDEA2021.1 配置大全(超详细教程)

    这篇文章主要介绍了IntelliJ IDEA2021.1 配置大全(超详细教程),需要的朋友可以参考下...2021-04-18
  • 解决IDEA 左侧Project中没有out文件夹的问题

    这篇文章主要介绍了解决IDEA 左侧Project中没有out文件夹的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-08
  • idea 修改项目名和module名称的操作

    这篇文章主要介绍了idea 修改项目名和module名称的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-13
  • 关于idea一直卡在build不动的解决方案

    这篇文章主要介绍了idea一直卡在build不动的解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-10-21
  • Intellij IDEA连接Navicat数据库的方法

    这篇文章主要介绍了Intellij IDEA连接Navicat数据库的方法,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借价值,需要的朋友可以参考下...2021-03-25
  • idea 访问html页面端口号显示的是63342而不是8080

    这篇文章主要介绍了idea 访问html页面端口号显示的是63342而不是8080,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-08-11
  • intelliJ IDEA 多行选中相同内容的快捷键分享

    这篇文章主要介绍了intelliJ IDEA 多行选中相同内容的快捷键分享,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-06
  • 解决IDEA占用C盘空间过大的问题

    这篇文章主要介绍了解决IDEA占用C盘空间过大的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-22
  • 解决idea2020 maven无法自动导包的问题

    这篇文章主要介绍了解决idea2020 maven无法自动导包的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-13
  • intellij idea快速查看当前类中的所有方法(推荐)

    这篇文章主要介绍了intellij idea快速查看当前类中的所有方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-09-02
  • 解决IDEA maven 项目修改代码不生效,mvn clean、install后才生效

    这篇文章主要介绍了解决IDEA maven 项目修改代码不生效,mvn clean、install后才生效的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-09-25
  • IDEA中的clean,清除项目缓存图文教程

    这篇文章主要介绍了IDEA中的clean,清除项目缓存图文教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-09-25
  • idea 打包maven项目忽略test文件的操作

    这篇文章主要介绍了idea 打包maven项目忽略test文件的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-05
  • Android模拟器上模拟来电和短信配置

    如果我们的项目需要做来电及短信的功能,那么我们就得在Android模拟器开发这些功能,本来就来告诉我们如何在Android模拟器上模拟来电及来短信的功能。 在Android模拟...2016-09-20
  • 解决IDEA插件市场Plugins无法加载的问题

    这篇文章主要介绍了解决IDEA插件市场Plugins无法加载的问题,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-10-21
  • 夜神android模拟器设置代理的方法

    夜神android模拟器如何设置代理呢?对于这个问题其实操作起来是非常的简单,下面小编来为各位详细介绍夜神android模拟器设置代理的方法,希望例子能够帮助到各位。 app...2016-09-20
  • PHP函数分享之curl方式取得数据、模拟登陆、POST数据

    废话不多说直接上代码复制代码 代码如下:/********************** curl 系列 ***********************///直接通过curl方式取得数据(包含POST、HEADER等)/* * $url: 如果非数组,则为http;如是数组,则为https * $header:...2014-06-07
  • C#模拟http 发送post或get请求的简单实例

    下面小编就为大家带来一篇C#模拟http 发送post或get请求的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-06-25
  • IDEA 2021.2 激活教程及启动报错问题解决方法

    这篇文章主要介绍了IDEA 2021.2 启动报错及激活教程,文章开头给大家介绍了idea2021最新激活方法,关于idea2021启动报错的问题小编也给大家介绍的非常详细,需要的朋友可以参考下...2021-10-15
  • IDEA如何添加配置文件到classpath中

    这篇文章主要介绍了IDEA如何添加配置文件到classpath中,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-19