zoukankan      html  css  js  c++  java
  • git 分支修改bug应用场景

    总结:


    1.在dev分支日常开发

    2.出现bug(或紧急需求),需要立即处理部署

    3.  git stash (备份工作区) 或 git commit (提交到本地) dev分支当前修改

    4.切换至主分支 git checkout master

    5.修改bug、commit push 到 master分支,并形成临时 test release ,测试

    6.服务器部署git pull origin master,验收bug(或需求)

    7.切换回dev分支 git checkout dev

    8.把主分支的改动合并到dev分支,git merge master,可能会有冲突,手动处理冲突

    9.如果第3部使用的是git stash ,则这里需要 git stash pop 把dev分支保存的修改再拿出来(也可能会有冲突,手动处理冲突),后继续dev分支的开发



    参考:

    http://www.cppblog.com/deercoder/archive/2011/11/13/160007.aspx



    最近在使用Git管理项目工程的时候,遇到了很多问题,也学习到了很多关于Git常见使用的技巧,下面就其中关于Git Stash的用法和大家分享下。
    首先,简单介绍下Git Stash命令的用法,详细的用法在man文档中有相关介绍,下面我来说明常见的使用。
    git stash: 备份当前的工作区的内容,从最近的一次提交中读取相关内容,让工作区保证和上次提交的内容一致。同时,将当前的工作区内容保存到Git栈中。
    git stash pop: 从Git栈中读取最近一次保存的内容,恢复工作区的相关内容。由于可能存在多个Stash的内容,所以用栈来管理,pop会从最近的一个stash中读取内容并恢复。
    git stash list: 显示Git栈内的所有备份,可以利用这个列表来决定从那个地方恢复。
    git stash clear: 清空Git栈。此时使用gitg等图形化工具会发现,原来stash的哪些节点都消失了。
    关于Git Stash的详细解释,适用场合,这里做一个说明:

    使用git的时候,我们往往使用branch解决任务切换问题,例如,我们往往会建一个自己的分支去修改和调试代码, 如果别人或者自己发现原有的分支上有个不得不修改的bug,我们往往会把完成一半的代码 commit提交到本地仓库,然后切换分支去修改bug,改好之后再切换回来。这样的话往往log上会有大量不必要的记录。其实如果我们不想提交完成一半或者不完善的代码,但是却不得不去修改一个紧急Bug,那么使用'git stash'就可以将你当前未提交到本地(和服务器)的代码推入到Git的栈中,这时候你的工作区间和上一次提交的内容是完全一样的,所以你可以放心的修 Bug,等到修完Bug,提交到服务器上后,再使用'git stash apply'将以前一半的工作应用回来。也许有的人会说,那我可不可以多次将未提交的代码压入到栈中?答案是可以的。当你多次使用'git stash'命令后,你的栈里将充满了未提交的代码,这时候你会对将哪个版本应用回来有些困惑,'git stash list'命令可以将当前的Git栈信息打印出来,你只需要将找到对应的版本号,例如使用'git stash apply stash@{1}'就可以将你指定版本号为stash@{1}的工作取出来,当你将所有的栈都应用回来的时候,可以使用'git stash clear'来将栈清空。
    在这里顺便提下git format
    -patch -n , n是具体某个数字, 例如 'git format-patch -1' 这时便会根据log生成一个对应的补丁,如果 'git format-patch -2' 那么便会生成2个补丁,当然前提是你的log上有至少有两个记录。

    看过上面的信息,就可以知道使用场合了:当前工作区内容已被修改,但是并未完成。这时Boss来了,说前面的分支上面有一个Bug,需要立即修复。可是我又不想提交目前的修改,因为修改没有完成。但是,不提交的话,又没有办法checkout到前面的分支。此时用Git Stash就相当于备份工作区了。然后在Checkout过去修改,就能够达到保存当前工作区,并及时恢复的作用。

    下面,将我使用过程中遇到的一个问题和大家分享:

    首先,在Git Stash之后,提交图如下所示:

    从图中可以看到,develop和newdevelop是在同一个分支上,因为分支newdevelop是在develop分支的基础上开发的。想加入一个新的特性,所以就开了newdevelop分支,然后就在上面加东西,加特性,该代码。这个时候工作的内容已经变化了,但是develop和newdevelop都是指向同一个提交的,因为newdevelop上面还木有提交。
    这个时候,Boss来了,说develop上面有个Bug,赶快改一下,手头的工作先放放,稳定版本不能有缺陷。没办法,当前正在newdevelop上搞的high呢,就Git Stash一下。所以会看到上面有两个节点,红色以及上面一个。就是stash之后的结果,注意是在newdevelop上面进行的stash。

    正如前面所说,stash会暂存当前的工作区内容,然后将工作区内容保持和上次提交相同,此时内容都是上面8a32那个提交的内容。从终端中查看相应的信息内容,如下:

    印证了签名的说法,newdevelop是有修改,modified,然后stash之后,工作区是最近一次提交,此时newdevelop和develop都是相同的,所以再git status查看发现,都一样,nothing to commit.

    然后Stash完成之后,就要Fix Bug了。为此,回到develop分支上进行修复,然后提交,完成后的提交图如下所示:
    从途中可以看到,newdevelop还是在下面,因为指向的是老的那个8a32的commit。新的develop由于修复了Bug,所以产生一个新提交。


    然后在develop上面修复了Bug之后,在回到newdevelop上面进行一个新的特性的继续编码,此时checkout回去的时候,没有神马内容可以提交,因为都存在Stash中了,没有任何修改。如上图。

    那么,恢复工作区内容吧。于是git stash pop(注意这里由于只Stash了一次所以使用pop,具体你存放了多少,要恢复哪一个要自己清楚,否则会出错!)

    恢复之后,从上图中可以看到,此时再git status就会发现文件有修改,说明恢复过来了。然后就继续编码,提交一个稳定的新特性版本,如下图,产生的新提交为0906.
    然后再查看提交图,会发现,stash pop之后,对应的存放的stash被清空掉了,提交图中,newdevelop上面对应一个新的提交。并且在develop上面。分支的develop那个红色,即为前面修复Bug的那个提交。


    总结起来:
    操作很简单,但是头脑要清楚。要在哪个分支上修复Bug,要暂存哪个地方的内容,之后修复完了在那个地方提交,然后要到哪个分支上面恢复工作区,都是需要注意的,否则,很容易造成提交图混乱。只有弄清楚了工作流程,才不容易出错,才能保证很高的工作效率。
    最后一句:Git是神器,就要看你如何驾驭它了。



    https://wenku.baidu.com/view/6a25f40653d380eb6294dd88d0d233d4b14e3f35.html



    git stash 

    可用来暂存当前正在进行的工作,

     

    比如想

    pull 

    最新代码,

     

    又不想加新

    commit

     

    或者另外一种情

    况,为了

    fix 

    一个紧急的

    bug,  

    stash, 

    使返回到自己上一个

    commit, 

    改完

    bug

    之后再

    stash pop, 

    继续原来

    的工作。

    基础命令:

    $git stash

    $do some work

    $git stash pop

    在使用git pull代码时,经常会碰到有冲突的情况,提示如下信息:

    e

    r

    r

    o

    r

    :

     

    Y

    o

    u

    r

     

    l

    o

    c

    a

    l

     

    c

    h

    a

    n

    g

    e

    s

     

    t

    o

     

    '

    c

    /

    e

    n

    v

    i

    r

    o

    n

    .

    c

    '

     

    w

    o

    u

    l

    d

     

    b

    e

     

    o

    v

    e

    r

    w

    r

    i

    t

    t

    e

    n

     

    b

    y

     

    m

    e

    r

    g

    e

    .

     

     

    A

    b

    o

    r

    t

    i

    n

    g

    .

    P

    l

    e

    a

    s

    e

    ,

     

    c

    o

    m

    m

    i

    t

     

    y

    o

    u

    r

     

    c

    h

    a

    n

    g

    e

    s

     

    o

    r

     

    s

    t

    a

    s

    h

     

    t

    h

    e

    m

     

    b

    e

    f

    o

    r

    e

     

    y

    o

    u

     

    c

    a

    n

     

    m

    e

    r

    g

    e

    .

    这个意思是说更新下来的内容和本地修改的内容有冲突,先提交你的改变或者先将本地修改

    暂时存储起来。

    处理的方式非常简单,主要是使用git stash命令进行处理,分成以下几个步骤进行处理。

    1、先将本地修改存储起来

    $

     

    g

    i

    t

     

    s

    t

    a

    s

    h

    这样本地的所有修改就都被暂时存储起来 。是用git stash list可以看到保存的信息:

    git stash暂存修改

    其中stash@{0}就是刚才保存的标记。

    2、pull内容

    暂存了本地修改之后,就可以pull了。

    $

     

    g

    i

    t

     

    p

    u

    l

    l

    3、还原暂存的内容

    $

     

    g

    i

    t

     

    s

    t

    a

    s

    h

     

    p

    o

    p

     

    s

    t

    a

    s

    h

    @

    {

    0

    }

    系统提示如下类似的信息:

    A

    u

    t

    o

    -

    m

    e

    r

    g

    i

    n

    g

     

    c

    /

    e

    n

    v

    i

    r

    o

    n

    .

    c

    C

    O

    N

    F

    L

    I

    C

    T

     

    (

    c

    o

    n

    t

    e

    n

    t

    )

    :

     

    M

    e

    r

    g

    e

     

    c

    o

    n

    f

    l

    i

    c

    t

     

    i

    n

     

    c

    /

    e

    n

    v

    i

    r

    o

    n

    .

    c

    意思就是系统自动合并修改的内容,但是其中有冲突,需要解决其中的冲突。

    4、解决文件中冲突的的部分

    打开冲突的文件,会看到类似如下的内容:

    git冲突内容

    其中Updated upstream 和=====之间的内容就是pull下来的内容,====和stashed

    changes之间的内容就是本地修改的内容。碰到这种情况,git也不知道哪行内容是需要的,

    所以要自行确定需要的内容。

    解决完成之后,就可以正常的提交了。


  • 相关阅读:
    项目分析时找不到函数调用只有16进制数
    firebase消息推送配置
    布局错乱到原点的问题
    人脸识别部分文章地址笔记
    查看奔溃分析
    iOS App 后台任务的坑(奔溃原因分析)
    轨迹优化
    X SqlServer 事务日志传输 【将备份目录设置到辅助服务器】
    X sql server2014 发布与订阅的配置方法介绍包括【推送订阅】与【请求订阅】
    X SQL SERVER 使用订阅发布同步数据库 【推送订阅】
  • 原文地址:https://www.cnblogs.com/silyvin/p/9106729.html
Copyright © 2011-2022 走看看