【Git使用详解】Egit的常用操作详解

常用操作



操作


说明


Fetch


从远程获取最新版本到本地,不会自动merge


Merge


可以把一个分支标签或某个commit的修改合并现在的分支上


Pull


从远程获取最新版本并merge到本地相当于fetch+merge


Push


将本地分支的更新,推送到远程主机


Merge tool


当你的代码产生了冲突可以通过此工具快速的对比


Switch to


将当前分支切换到其它分支或标签


Commit


将更改提交到本地库中


Rebase


可以把在一个分支里提交的改变移到另一个分支里重放一遍


Reset


将当前分支切换到本分支以前的任何一个版本状态,即所谓的“回溯”

EGit的恢复版本功能与使用Git Reset命令一样,而恢复的方式又分为Soft、Mixed、Hard三种:
•Soft:恢复到前面版本,保留文件变更内容,且将已变更的所有文件加到准备区(Staging Area)。
•Mixed:恢复到前面版本,保留所有已变更文件的变更内容。
•Hard:恢复到前面版本,不保留所有已变更文件的变更内容。


Untrack


将已经添加到版本控制的文件取消监视,及不再对其进行版本控制


Ignore


忽略指定的文件或文件夹,此功能用在还没有进行版本控制的文件上


Compare with


此功能允许你将当前文件和指定时期的文件进行对比

常用操作对比


Branch和Tag的区别:

tag多用于建立里程碑。比如开发达到某中程度,发布某个版本,如V1.0,可以使用tag标注。这样,以后对于程序版本号就可以找到对应的代码状态,并进行build等操作。理论上,tag作为里程碑的镜像存储,应该是只读的才对。

相比,branch是工程需要并行开发不同版本而创建的。如一个原型项目完成后,可能有不同的客户购买并定制,于是就需要在这个原型上构建两个独立的开发库,各自并行开发不同客户的需要。这样,branch可以是进程中的工程,而且之后会不断修改的。

由此,可以看出tag和branch的差别。tag更重要的是记录某个里程碑,只是希望得到那个状态时的代码状态,这对bug的确认和查找很有用处。而各个branch之间是可以肆意各自的改动,互不相干的,branch上也可以有自己的tag。

Merge和Rebase的区别:

下面通过一个实例来讲解一下两种方式的区别:

假设原先有A,B,C三个提交记录

开发者提交了D,开发者 Ed提交了E

下面使用MERGE和REBASE两种方式分别对代码进行合并

MERGE方式:

这时D和E的提交仍然在这,但是我们创建了一个新的提交记录M,此时的状态图成了一个菱形,这让很多人看起来很混乱。

REBASE方式:

从上图可以看出这种方式创建了提交R,这时的内容和M实际上是相同的。但是这时没有了E,所以整个提交记录是看起来是一条线。

推荐阅读:

【Git使用详解】Egit插件的安装图解

【Git使用详解】使用Egit克隆项目到本地图解

【Git使用详解】Git的使用心得

【Git使用详解】Egit使用过程中遇到的问题及解决办法

时间: 2024-10-12 10:44:59

【Git使用详解】Egit的常用操作详解的相关文章

Linux Shell数组常用操作详解

Linux Shell数组常用操作详解 1数组定义: declare -a 数组名 数组名=(元素1 元素2 元素3 ) 1 declare -a array 2 array=(1 2 3 4 5) 数组用小括号括起,数组元素之间用空格分开 2显示数组长度: [@tc_132_227 dm_pid_day]$ echo ${#array[@]} 5 [@tc_132_227 dm_pid_day]$ echo ${#array[*]} 5 命令: ${#数组名[@或*]} 获取数组长度,若数组无

Linux常用操作详解

第1章 Linux命令基础 1.1 习惯 操作前备份,操作后检查 1.2 简单目录结构 一切从根开始,与windows不同 1.3 规则 [[email protected] ~]# [用户名@主机名 你在哪]# 1.4 重定向符号 特殊符号-重定向符号:泼水 1.4.1 输出重定向 >或1>   标准输出重定向: 先把原文件的内容清空,然后把新的内容放到文件中 >>或1>> 追加输出重定向: 把前面输出的东西输入到后边的文件中,不会清除文件原有内容,只是追加到文件的最

【软件构造】(转)Git详解、常用操作与版本图

版本控制与Git 转自:http://www.cnblogs.com/angeldevil/p/3238470.html 版本控制 版本控制是什么已不用在说了,就是记录我们对文件.目录或工程等的修改历史,方便查看更改历史,备份以便恢复以前的版本,多人协作... 一.原始版本控制 最原始的版本控制是纯手工的版本控制:修改文件,保存文件副本.有时候偷懒省事,保存副本时命名比较随意,时间长了就不知道哪个是新的,哪个是老的了,即使知道新旧,可能也不知道每个版本是什么内容,相对上一版作了什么修改了,当几个

【Git】Git远程操作详解

Git是目前最流行的版本管理系统,学会Git几乎成了开发者的必备技能. Git有很多优势,其中之一就是远程操作非常简便.本文详细介绍5个Git命令,它们的概念和用法,理解了这些内容,你就会完全掌握Git远程操作. git clone git remote git fetch git pull git push 本文针对初级用户,从最简单的讲起,但是需要读者对Git的基本用法有所了解.同时,本文覆盖了上面5个命令的几乎所有的常用用法,所以对于熟练用户也有参考价值. 一.git clone 远程操作

[转]Git远程操作详解

Git 是目前最流行的版本管理系统,学会 Git 几乎成了开发者的必备技能. Git 有很多优势,其中之一就是远程操作非常简便.本文详细介绍 5 个 Git 命令,它们的概念和用法,理解了这些内容,你就会完全掌握 Git 远程操作. git clone git remote git fetch git pull git push 本文针对初级用户,从最简单的讲起,但是需要读者对 Git 的基本用法有所了解.同时,本文覆盖了上面 5 个命令的几乎所有的常用用法,所以对于熟练用户也有参考价值. 一.

【转】 Git 常用命令详解(二)----不错

原文网址:http://blog.csdn.net/ithomer/article/details/7529022 Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍,请参考我的上一篇博客:Git 版本管理工具 一. Git 命令初识 在正式介绍Git命令之前,先介绍一下Git 的基本命令和操作,对Git命令有一个总体的认识 示例:从Git 版本库

【Objective-C】NSDate详解及获取当前时间等常用操作

NSDate类用于保存时间值,同时提供了一些方法来处理一些基于秒级别时差(Time Interval)运算和日期之间的早晚比较等. 1. 创建或初始化可用以下方法 用于创建NSDate实例的类方法有 + (id)date; 返回当前时间 + (id)dateWithTimeIntervalSinceNow:(NSTimeInterval)secs; 返回以当前时间为基准,然后过了secs秒的时间 + (id)dateWithTimeIntervalSinceReferenceDate:(NSTi

Git 入门和常用命令详解

git 使用使用教程   git 使用简易指南  常用 Git 命令清单 下载   https://git-scm.com/downloads 工作流 本地仓库由三部分组成. 工作区:保存实际的文件(本地实际的文件目录) 缓存区(Stage / Index):临时保存文件改动 HEAD:指向最近一次提交的后果 下图说明了 Git 的工作流程 图片来源:http://www.runoob.com Git 常用命令 git init 创建新仓库.在当前目录中创建新的 Git 仓库,生成.git文件夹

git 常用命令详解

最重要2命令: git clone git://github.com/schacon/grit.git 从服务器上将代码给拉下来 git pull 本地与服务器端同步 一. Git 命令初识 在正式介绍Git命令之前,先介绍一下Git 的基本命令和操作,对Git命令有一个总体的认识 示例:从Git 版本库的初始化,通常有两种方式: 1)git clone:这是一种较为简单的初始化方式,当你已经有一个远程的Git版本库,只需要在本地克隆一份 例如:git clone git://github.co