一、Git冲突解决
在idea开发工具中使用Git时,主要用到的快捷按钮如下五个:
 
这五个按钮的使用说明及在idea中如何配置和使用git可参考https://github.com/DayThink/IntelliJ-IDEA-Tutorial/blob/newMaster/vcs-introduce.md
本文主要讲解在Idea中利用git遇到的两种冲突(提交代码时发生冲突和更新代码时发生冲突)以及解决方法,无论是那种冲突,只要发生冲突了,idea都会弹出一个图形化的merge对话框,在merge对话框上引导用户去解决冲突。
1.提交commit冲突:
 
如上图所示,当提交代码时发生冲突,此时操作步骤如下
 
在这里我们希望将本地冲突代码和服务端的代码都保留,此时在上图中点击中间的两个红色按钮后即可将本地和服务端的冲突代码全部保留,在中间一栏result中科院预览到冲突解决后的代码情况,冲突处理完成后如下图
 
在上图merge对话框中点击右下角的apply时,一般会在idea的右下角出现如下的Push rejected提示对话框
 
上图对话框提示我们,在push的时候发生了失败,此时要注意,将本地代码更新提交到服务端,需要经历两个步骤:commit和push,commit相当于提交到了本地库,而push则是将本地库提交更新到服务端。根据上图提示push rejected,我们可以发现冲突已经在本地库commit时解决了,我们只需push一次即可,因此后续操作只需要push一次即可,如下:
在冲突的文件上,右键
 
push完成后即可将本地库的文件提交到服务端。
2.更新update冲突
 
如上图所示,点击更新按钮时发现冲突,提示用户如下所示的merge页面上进行冲突的处理,比如此处我们希望将本地修改和远端服务器的修改均保留,因此按照如下图所示的红色1和2操作,合并到中间的result一栏中。
 
冲突解决后,如下所示:
 
至此,更新冲突就已解决完成。
二.Git命令的全家福手册
 
三、idea中查看远程Git仓库的地址
有时我们需要将本地的代码与远程Git仓库脱离绑定关系或重新绑定到另一个Git仓库上,此时在idea中查看或删除本地代码对应Git仓库的方法:
 
如果本地的仓库绑定了两个远端的Git仓库,那么在弹出的Remotes对话框中会有两条远端Git仓库的记录。
四.idea中查看本地Git仓库的地址
查看与远程Git仓库绑定的本地目录,有时候本地目录和子目录都会绑定到一个远端的Git仓库。
五.用Git命令行(不在idea操作)上传本地仓库到Git远程仓库
如果是新项目,创建 git 仓库:
[java] view plain copy
  1. mkdir SpringBootInAction
  2. cd SpringBootInAction
  3. git init
  4. ##将当前目录下的所有文件添加到git仓库
  5. git add .
  6. git commit -m "first commit"
  7. ##首先要建好一个远端仓库(URL),如https://xxx/SpringBootInAction.git
  8. git remote add origin https://xxx/SpringBootInAction.git
  9. git push -u -f origin master
如果是已有项目
[java] view plain copy
  1. cd existing_git_repo
  2. git remote add origin https://xxx/SpringBootInAction.git
  3. git push -u origin maste
六.Git版本回退
首先,根据git提交的历史记录中确定回退的版本
 
将上述拷贝的Revision Number记录下来,如:4b91ea12de20cdf97eccb6bc9125bbc2fef79b17
备注:后面两步在idea中好似不能图形化操作界面,只能用命令行了
其次,恢复到指定的commit hash
git reset --hard resetVersionHash
eg:git reset --hard 4b91ea12de20cdf97eccb6bc9125bbc2fef79b17
最后,把当前分支强制提交到远程
git push -f origin currentBranch
eg: push -f origin master
以上三步操作后,就将本地和git远端的代码从2017-8-12 18:45回退到了2017-8-12 17:01。
七、分支操作
7.1.新建分支
1.首先在本地新建一个分支,如dev;
 
2.执行git push origin dev:dev;或git push origin dev;
上面命令表示,将本地的dev分支推送到origin主机的dev分支,如果后者不存在,则会被新建。
git push命令用于将本地分支的更新,推送到远程主机,它的格式如下:
$ git push <远程主机名> <本地分支名>:<远程分支名>
如果省略远程分支名,则表示将本地分支推送与之存在”追踪关系”的远程分支(通常两者同名),如果该远程分支不存在,则会被新建。
$ git push origin master
上面命令表示,将本地的master分支推送到origin主机的master分支,如果后者不存在,则会被新建。
如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。
$ git push origin :master
# 等同于
$ git push origin --delete master
上面命令表示删除origin主机的master分支。
如果当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略。
$ git push origin
上面命令表示,将当前分支推送到origin主机的对应分支。
如果当前分支只有一个追踪分支,那么主机名都可以省略。
$ git push
最后需要注意与git pull的区别,从远程分支名拉到(合并)本地分支名上:
$ git pull <远程主机名> <远程分支名>:<本地分支名>
7.2.本地与origin分支的对应设置
查看本地分支与远端origin的分支对应情况
$ git remote show origin设置本地分支与远端分支的对应关系,如:将本地dev分支与远端的dev分支进行绑定
git branch --set-upstream dev origin/dev
7.3分支合并
如下所示,将feature分支合并到dev分支,之后将合并后的dev分支push一次到origin即可。
7.4.远端origin分支查看及操作
[java] view plain copy
    1. git remote -v
    2. git remote add origin_didi git@git.xiaojukeji.com:sec/ews-parent.git
    3. git remote -v
    4. git remote --help
    5. git remote remove origin
    6. git remote -v
    7. git remote rename origin_didi origin
    8. git remote -v
    9. git push origin master

Idea中Git的使用和两种类型的冲突解决的更多相关文章

  1. .net中创建xml文件的两种方法

    .net中创建xml文件的两种方法 方法1:根据xml结构一步一步构建xml文档,保存文件(动态方式) 方法2:直接加载xml结构,保存文件(固定方式) 方法1:动态创建xml文档 根据传递的值,构建 ...

  2. PHP中实现MySQL嵌套事务的两种解决方案

    PHP中实现MySQL嵌套事务的两种解决方案 一.问题起源 在MySQL的官方文档中有明确的说明不支持嵌套事务: Transactions cannot be nested. This is a co ...

  3. Java中的ReentrantLock和synchronized两种锁定机制的对比

    问题:多个访问线程将需要写入到文件中的数据先保存到一个队列里面,然后由专门的 写出线程负责从队列中取出数据并写入到文件中. http://blog.csdn.net/top_code/article/ ...

  4. Ajax中的get和post两种请求方式的异同

    Ajax中我们经常用到get和post请求.那么什么时候用get请求,什么时候用post方式请求呢? 在做回答前我们首先要了解get和post的区别.   1. get是把参数数据队列加到提交表单的A ...

  5. JSP页面中的pageEncoding和contentType两种属性

    关于JSP页面中的pageEncoding和contentType两种属性的区别: pageEncoding是jsp文件本身的编码 contentType的charset是指服务器发送给客户端时的内容 ...

  6. 在Quartus II中分配管脚的两种常用方法

    在Quartus II中分配管脚的两种常用方法 示范程序 seg7_test.v 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 /* * ...

  7. strus2中获取表单数据 两种方式 属性驱动 和模型驱动

    strus2中获取表单数据 两种方式 属性驱动 和模型驱动 属性驱动 /** * 当前请求的action在栈顶,ss是栈顶的元素,所以可以利用setValue方法赋值 * 如果一个属性在对象栈,在页面 ...

  8. 在asp.net中使用confirm可以分为两种:

    在asp.net中使用confirm可以分为两种: 1.没有使用ajax,confirm会引起也面刷新 2.使用了ajax,不会刷新 A.没有使用ajax,可以用StringBuilder来完成. ( ...

  9. 在Delphi中使用C++对象(两种方法,但都要改造C++提供的DLL)

    Delphi是市场上最好的RAD工具,但是现在C++占据着主导地位,有时针对一个问题很难找到Delphi或Pascal的解决方案.可是却可能找到了一个相关的C++类.本文描述几种在Delphi代码中使 ...

随机推荐

  1. less变量插值

    在使用less的过程中,我在background的中引用图片路径,希望先确定一个baseurl,然后再在url中使用拼接字符串的方式拼接,尝试多次,失败. 实际上less的变量插值是有自己的一套规则的 ...

  2. Java日记

    总结关于Java web一些知识 VisualVM性能分析    ——  更好的理解JVM中的参数 JVM初始    ——    理解JVM 自己的Java开发规范  ——  个人Java开发是遵循的 ...

  3. JPA为字段设置默认值

    http://blog.csdn.net/u011983531/article/details/51286839 在使用JPA时,如果需要为属性设置默认值,很自然的,你可能会想到用下面的方式. @Co ...

  4. .Net程序员玩转Android系列之二~Android Framework概要(1)

    从windows操作系统说起 人们总是喜欢从将陌生的事物和自己所了解的东西关联起来,以加深对未知事物的了解,这一讲我们从windows操作系统说起,逐步引领带大家走入android的世界.写任何程序都 ...

  5. MAC OS===>IntelliJ IDEA__ant__zookeeper源码编译

    1:配置ant环境 https://archive.apache.org/dist/ant/binaries/  官网下载文件  1.10.0以上需要JDK1.8以上 否则会报 Exception i ...

  6. Uva 1378 - A Funny Stone Game

    1378 - A Funny Stone Game Time limit: 3.000 seconds The funny stone game is coming. There are n pile ...

  7. 基于easyUI实现权限管理系统(一)一—组织结构树图形

    此文章是基于 EasyUI+Knockout实现经典表单的查看.编辑 一. 相关文件介绍 1. organize.jsp:组织结构树的主界面 <!DOCTYPE html PUBLIC &quo ...

  8. About custom Theme and Style

    For android system, of course you can custom your own style and theme, but you can't break compatibi ...

  9. PAT 1048. Find Coins

    two sum题目,算是贪婪吧 #include <cstdio> #include <cstdlib> #include <vector> #include &l ...

  10. 监听css3的animation动画和transition事件

    webkit-animation动画有三个事件: 开始事件: webkitAnimationStart 结束事件: webkitAnimationEnd 重复运动事件: webkitAnimation ...