赞
踩
目录
把工作空间,从开发主线上分离出来,以免影响开发主线
Master分支,一般为主分支,应该是最稳定分支,用来打包发布。一般不允许在此分支上进行开发,日常的开发工作需要新建分支(一般命名为dev),在dev分支开发完成并测试通过后(稳定后),可以执行合并dev分支代码到Master分支上。
查看 本地分支 及 本地缓存 的 远程分支
git branch -a
Git中 * 标识的分支,为你当前所在分支
Idea中,黄色星星标识的为主分支(本地及远程)
git checkout 分支名
会直接切换到本地的dev分支上,此时代码展示的为本地的dev上的
会提示无法匹配到一致的分支
仅仅创建新分支,是不会被计入Contribution。
git checkout -b 分支名
相当于创建并切换:
a.创建新的本地dev分支;
b.将 当前分支代码 复制到dev分支上;
c.切换到dev分支。
此时dev上的代码与当前分支上的代码完全相同。
- 等同于依次执行以下两步:
- (a):git branch dev 创建新的本地dev分支 并把当前master代码复制到dev上
- (b):git checkout dev 切换到dev分支
提示创建失败,此分支已存在
git checkout -B
强制创建新的分支,如果当前仓库中,已经存在一个跟你新建分支同名的分支,那么使用普通的 git checkout -b 这个命令,是会报错,且同名分支无法创建。如果使用-B参数,那么就可以强制创建新的分支,并会覆盖掉原来的分支代码。
例如,将 dev 分支代码 合并到 master 分支,则需本地先切换至 master 分支 后,执行以下操作
git merge dev
- 1、远程 没有 dev 分支 ,且 本地已经切换到 dev 分支(相当于创建远程的dev分支)
- 执行:
- git push origin dev:dev
- 或:
- git push origin HEAD -u
-
- 例如:将当前master分支代码推送到master-20191009分支上,如果新分支不存在,则创建并推送
- 执行:
- git push origin master:master-20191009
- 或:
- git push origin HEAD -u
-
- 注意:仅仅创建新分支,是不会被计入Contribution。
-
-
-
-
- 2、远程 已有 dev 分支 ,且 远程dev分支 未关联 本地dev分支 且本地已经切换到 dev
- 执行:
- git push -u origin dev
-
-
-
-
- 3、远程 已有 dev 分支 ,且 远程dev分支 已关联 本地dev分支 且本地已经切换到 dev
- 执行:
- git push
- 或
- git push origin dev
-
远程dev分支代码 领先于 本地dev分支代码, 且此领先部分需要去除,此时本地dev分支代码中不存在 远程dev分支领先的代码,则无法进行删除,此时就要将 本地dev分支的代码 强行推送 覆盖掉远程dev分支代码
(a)本地所在分支 即为想要强推的分支
git push -f
(b)本地所在分支 不是想要强推的分支。(将 pre 分支代码到 强推至 master,既覆盖掉master代码)
- $ git push -f origin 源分支:目标分支
-
- $ git push origin 源分支:目标分支 -f
不同的开发人员对统一段代码进行修改,后推送的人会报错(如下图)
idea中显示如下:
<<<<head 与 ====== 之间 的内容 为你在本地编辑的内容,
======== 与 >>>>>>>之间的 为远程仓库中的内容
选择保留哪个 然后 依次执行
- git add .
-
- git commit -m "备注信息"
-
- git push origin master
仅删掉了branch的指针,并未直接改变history log的结构
git branch –d dev
git push origin --delete dev
注意:
执行 git branch -d XX 可能提示: the branch XX is not fully merged原因:
XX分支有没有合并到当前分支的内容
解决方法:
使用大写的D 强制删除 git branch -D XX
另外:
不能删除当前 checkout 的分支
其它:
删除远程分支 需要切换到其它分支之后删除当前分支
否则会:
error:cannot delete the branch 'XXX' which you are currently on
(a)本地 拉取 与远程 是同一个分支的代码
git pull origin dev
- // 从远程主机的master分支拉取最新内容
- git fetch origin master
-
-
- // 将拉取下来的最新内容合并到当前所在的分支中
- git merge FETCH_HEAD
(b)本地 拉取 与远程 是不同分支的代码
将远程主机的某个分支的更新取回,并与本地指定的分支合并
git pull <远程主机名> <远程分支名>:<本地分支名>
如:本地的当前分支为master,则此时会将dev的代码合并到master上
git pull origin dev:master
(a)从远程下载最新的,而不尝试合并或rebase任何东西
git fetch --all
(b)git reset 将主分支重置为您刚刚获取的内容。 --hard选项更改工作树中的所有文件以匹配origin/master中的文件。
git reset --hard origin/master
或者如果你在其他分支上:
git reset --hard origin/<branch_name>
(a)将本地新写的代码暂时的截取,并存储在缓存空间。执行此命令后 当前所写的代码会消失。
git stash
(b)将截取在缓存空间中的代码 释放出来 此命令如果不是在git stash之后使用,会释有一些奇奇怪怪的问题
git stash pop
- git remote update origin --prune
-
- git remote update origin -p
git config branch.分支名称.descripiton '注释内容'
查看分支注释,可添加git工具 git-br
- //npm 下载
- npm i -g git-br
查看时,执行命令
git commit -m "备注信息"
前提:在 push 操作 前
- // 取消上一次提交,并且将暂存区的文件重新提交。也可以不修改内容,仅对描述进行修改。
- git commit --amend
第一次的提交信息:
修正操作:执行 git commit --amend 命令,会出现下面的图例,其中黄色文字,为待修改的备注信息,直接删除重新编写;
保存操作:信息内容修改后,执行命令 英文冒号 : ,后输入wq 或 q,(“:wq”,表示write , quit :先将修改写到文件,然后退出)此时页面会跳转,之后可以执行正常的 push 操作
结果:
提交时忘记忽略 target* ,导致 target文件夹及下属文件 上传到远程仓库,在github上只能删除仓库,却无法删除文件夹或文件, 所以只能通过命令来解决
(a)使用dir命令,查询当前目录结构
(b)使用cd命令,进入对应子模块center,并再次使用dir命令,查询当前层目录结构,可以看到target文件夹
(c)在target所在目录层下,执行以下命令,进行删除操作
$ git rm -r --cached target 删除target文件夹
(d)之后就是提交 并push到远程
- $ git add .
- $ git commit -m '删除了target' 提交,添加操作说明
- $ git push origin master 将本次更改更新到github项目上去
(e)查看远程仓库,发现文件夹已消失
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。