如何使用Git管理代码

Git 是开发人员用来向代码库(msstash)中提交代码或者下载远端代码库中代码的工具。

如何使用git向代码库中提交我们修改后的代码呢?

1.如果是第一次使用git,那么需要在本地电脑上初始化一个代码仓库

cd定位到目录,然后执行 git init, 初始化代码仓库,创建了一个主分支master

如果已经初始化过代码库,那么需要将远程的代码库中的代码copy下来。

git clone "https://msstash.morningstar.com/XXXX"

git  status 查看当前的状态,非常有用
创建分支等一系列操作一定要进入项目中(cd d:/文件夹名字/项目名),不能在外面的文件夹中操作,否则就只能出错啦!~~~~(>_<)~~~~

2. 创建新分支, git branch feature/QS-7589

3. 转到新分支, git checkout feature/QS-7589

创建分支并切换到新分支:git checkout –b feature/QS-7859

4.在自己的电脑本地上对代码进行添加修改保存

5. 使用git add --all, 让文件被git跟踪, (每次修改后提交之前都要跟踪文件

如果只想提交某个文件,那么在使用这个命令时,使用git  add 文件名

6. 提交代码到本地,git commit -m
"some comments"

修改后的代码commit以后,如果要给别人检查一下,就直接在修改的分支下,执行如下命令行:

git  push  origin  feature/ID 
,是将分支代码push上去,以便其他人查看,如果不需要别人帮忙查看,不使用这个命令

每次commit代码都会产生一条记录在stash中,如果同一个任务commit太多次,就会显得很繁琐,不利于其他成员去看,所以应该将所有的commit合并成一条.

$ git  merge  –-squash 
 分支名    ------将分支名上的多个commit合并成一个,放在当前分支上。

$ git commit  -m “meaasge”     -----提交

或者将重复的,不需要的commit删掉。

$ git  log       ------查看commit记录,并记录下最新代码分支的commit号,使用q退出。

$ git  reset  --soft 
commit码

$ git  commit –m “ message”

如果对同一个问题,在同一个分支上commit了多次,而在某次只需要push某一次的commit,只需要切换到要合并到的主分支上,使用命令

$ git  cherry-pick  
commitId
 (!重要),这个commitId号,可以在msstash中查看到。

7. 提交代码到远端过程
a.转到公共分支    git  checkout  [公共分支]

b.将公共分支上的代码取下来      git pull --ff   (每次在push代码到库之前都必须pull一下,确保本地的代码更新到最新状态)

c.转到新分支         git  checkout  feature/ID

d.以公共分支为基准      git rebase [公共分支]

e.转到公共分支         git  checkout [公共分支]

f.将新的分支合并到公共分支上       git  merge --no-ff  feature/ID
      以上的操作都是在本地的分支进行的操作,以下是最后一步,才是将本地的公共分支合并到远端的公共分支上。

g.将合并后的公共分支上的代码推送到msstash代码库中    git  push  origin  [公共分支]

 

第一次push或者同样的分支push过,但是已经删除了,需要使用git  push  origin  [公共分支]

有时候bug比较小,在得到manager的同意后,可以直接在prestage上修改,修改完以后直接将在本地prestage上做的修改push到远端的prestage上。在本地prestage下,使用命令git  push  origin 
prestage将本地的代码push到远端的prestage上。

修改完prestage以后,还可以将代码push到远端的develop分支上,首先切换到本地的develop分支上,然后使用git
cherry-pick commitId,将prestage分支上的修改放到本地develop上。然后使用git push origin develop,这样就达到了将某个分支上的某次commit提交到远端的develop上的目的。

 


git branch 
只是查看本地代码的分支

git branch –a  查看所有代码库中的分支

如果在某一个分支上做了修改,但是不想提交代码就想切换到其他分支,可以使用命令:

git  stash , 然后再切换分支。

如果你想切换到刚刚修改过的分支后重新获得刚刚修改过的内容,则切换到这个分支以后,使用命令 git  stash  apply

如何在本地合并远端的分支,(假设要合并远端的分支origin/feature/add)

  1. 将远端代码clone下来
  2. 进入项目以后,使用命令:git fetch origin 远端分支名。获取远程更新
  3. 把更新的内容合并到本地分支:git   merge  origin/master

(在本地创建一个新的分支与远端的分支进行合并,使用命令:git checkout –b 本地分支名   origin/远端分支名)

删除分支

删除一个分支dev2:

  git branch –d dev2

  注意不能删除当前所在分支,需要转到别的分支上。

  如果要删除的分支已经成功合并到当前分支,删除分支的操作会直接成功。

  如果要删除的分支没有合并到当前所在分支,则会出现提示,如果确定无须合并而要直接删除,则执行命令:

  git branch –D dev2

  进行强删。

分支重命名

  重命名分支:

  git branch –m oldname newname

  -m不会覆盖已有分支名称,即如果名为newname的分支已经存在,则会提示已经存在了。

  如果改成-M就可以覆盖已有分支名称了,即会强制覆盖名为newname的分支,这种操作要谨慎。

为了避免误操作对远端代码库的影响,通常我们可以将远端的代码库fork一份,建立自己的代码库,然后从自己的代码库中clone一份代码到本地机器上。这样每次commit和push都是在自己的代码库中操作的,对远端的代码库没有影响,如果最后确认无误后,再将自己的代码库与远端的代码库合并,具体操作如下:

Git  fetch origin develop 把远端代码库中的develop分支上的代码拿到自己的代码仓库中,更新对应的develop分支

为了节省空间或者隐藏文件,通常把好几个文件打包压缩在一起给客户使用,但是当我们的功能出现了问题,需要改bug时,在浏览器中我们看到的也是压缩文件,很难调试这时就需要在本地将合成压缩文件的好几个文件打包在一起,去替换压缩的文件,用以下命令可以将多个文件打包合成一个文件替换。多个文件在gruntconfig文件夹里面,打包后的文件在release文件夹中

grunt qbuild --apicom=文件名 --apiunu=true

grunt qbuild --apicom=finra_common
--apiunu=true

grunt qbuild --apicom=calendar
--apiunu=true

如何使用git提交代码的更多相关文章

  1. git提交代码到github

    前言:转载请注明出处:http://blog.csdn.net/hejjunlin/article/details/52117504 git提交代码到github 命令汇总: git init git ...

  2. 使用git提交代码到github,每次都要输入用户名和密码的解决方法

    自从使用git提交代码到github后,发现自己使用git的功力增长了不少,但也遇到不少问题.比如,使用git提交代码到github的时候,经常要求输入用户名和密码,类似这种: 网上有这么一种解决方法 ...

  3. Git提交代码失败: empty ident name (for <>) not allowed

    使用git提交代码,报错如下: 下午2:56 Commit failed with error 0 files committed, 1 file failed to commit: 升级 empty ...

  4. 在使用Git提交代码的时候犯了个低级错误

    今天在使用git提交代码的时候,犯了个很低级的错误,按照一切流程当我add并commit提交代码,最后使用push到远程仓库, 接下来奇怪的事情发生了,push之后,查看远程仓库代码并没有发现提交记录 ...

  5. Git提交代码报错Git push error:src refspec XXX matches more than one解决方案

    Git提交代码push时,报错这个 error: src refspec master matches more than one. error: failed to push some refs t ...

  6. git提交代码到码云

    日常代码一般提交到github比较多,但我还是钟爱马爸爸,没错就是码云. 码云是中文版的代码托管的网站,不存在打开网速问题,使用也蛮方便的,日常自己保存托管代码已经足够,平时使用git提交代码到码云是 ...

  7. git提交代码报错 trailing whitespace的解决方法

    1. git提交代码报错 trailing whitespace 禁止执行pre-commit脚本 进入到项目目录中 chmod a-x .git/hooks/pre-commit 2.git提交代码 ...

  8. Git提交代码到主分区

    git 提交代码,本地新建一个my分支,不从本地master分支直接上传,而是先从本地my分支上提交至本地master分支,然后本地master提交至远程master分支 上.前提是远程只有一个mas ...

  9. git提交代码出现错误fatal: Unable to create '项目路径/.git/index.lock': File exists.

    git提交代码出现错误fatal: Unable to create '项目路径/.git/index.lock': File exists. 具体出错代码如下: 具体原因不详,在stackoverf ...

  10. 怎样解决git提交代码冲突

    当我们使用git提交代码时,别人可能也同一时候改动了我们改动的文件,可是别人的先合入到配置库里边,这样当我们的提交要合入时.就会产生冲突,能够使用下面步骤来解决冲突: (1) git rebase   ...

随机推荐

  1. 利用scp 远程上传下载文件/文件夹

    scp [-1246BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file] [-l limit] [-o ssh_option] [-P port ...

  2. go语言中net包tcp socket的使用

    一.通过socket我们模拟请求网易 package main; import ( "net" "log" "io/ioutil" &quo ...

  3. webapi 设置不显示接口到swaggerUI

    请添加如下属性: [ApiExplorerSettings(IgnoreApi = true)]

  4. hdu 1010(DFS) 骨头的诱惑

    http://acm.hdu.edu.cn/showproblem.php?pid=1010 题目大意从S出发,问能否在时间t的时候到达终点D,X为障碍 需要注意的是要恰好在t时刻到达,而不是在t时间 ...

  5. 探索未知种族之osg类生物---器官初始化四

    上一节我们对完成了对osg生物内部非常重要器官graphicsContext的初始化工作.这样就可保证我们场景中至少有一个graphicContext存在,不至于刚出生就面临夭折.我们根据上一节中os ...

  6. javascript 高级程序设计 十

    理解JS对象(2)创建对象   JS中创建对象的方式有很多,我们把他们统称为模式. 工厂模式: 优点:解决了创建多个相似对象的问题. 缺点:没有解决对象识别问题.(不知道一个实例对象的类型) func ...

  7. [转载]RPM中SPEC常用路径以及宏变量

    转自:http://blog.csdn.net/txgc1009/article/details/6833764 通过命令rpm --showrc查看实现代码.另外直接通过 rpm --eval &q ...

  8. DEDE 首页调用指定栏目链接的代码

    {dede:type typeid='6'} <a href='[field:typelink /]' target="_blank" >更多</a> {/ ...

  9. Data Dictionary 数据字典

    数据字典是一种通用的程序设计方法.可以认为,不论什么程序,都是为了处理一定的主体,这里的主体可能是人员.商品(超子).网页.接口.数据库表.甚至需求分析等等.当主体有很多的属性,每种属性有很多的取值, ...

  10. 【搜索】 Prime Path

    #include<cstdio> #include<cstring> #include<cmath> #include<queue> #include& ...