当前位置: 首页 > news >正文

淘宝客商品推广网站建设智能建站平台

淘宝客商品推广网站建设,智能建站平台,淮南营销型网站建设怎么样,网页设计的尺寸是指文章目录 基本用法引入多个提交代码冲突解决引入分支所有提交引入另一个代码库提交常用配置常见问题 此文在阅读前需要有一定的git命令基础,若基础尚未掌握,建议先阅读这篇文章Git命令播报详版 对于多分支的代码库,将代码从一个分支引入到另一…

文章目录

    • 基本用法
    • 引入多个提交
    • 代码冲突解决
    • 引入分支所有提交
    • 引入另一个代码库提交
    • 常用配置
    • 常见问题

此文在阅读前需要有一定的git命令基础,若基础尚未掌握,建议先阅读这篇文章Git命令播报详版

对于多分支的代码库,将代码从一个分支引入到另一个分支是常见需求。

这时分两种情况。一种情况是,你需要另一个分支的所有代码变动,那么就采用合并(git merge)。另一种情况是,你只需要部分代码变动(某几个提交),这时可以采用 cherry-pick

基本用法

git cherry-pick 命令的作用,就是将指定的提交(commit)应用于其他分支。

git cherry-pick <commitHash>

上面命令就会将指定的提交commitHash,应用于当前分支。这会在当前分支产生一个新的提交,当然它们的哈希值会不一样。

举例来说,代码仓库有master和feature两个分支。

    a - b - c - d   Master\e - f - g Feature

现在将提交f应用到master分支。

# 切换到 master 分支
git checkout master# cherry-pick 操作
git cherry-pick f

上面的操作完成以后,代码库就变成了下面的样子。

    a - b - c - d - f   Master\e - f - g Feature

从上面可以看到,master分支的末尾增加了一个提交f。

git cherry-pick命令的参数,不一定是提交的哈希值,分支名也是可以的,表示引入该分支的最新提交。

git cherry-pick feature

上面代码表示将feature分支的最近一次提交,引入到当前分支。

引入多个提交

cherry-pick 支持一次引入多个提交。

git cherry-pick <HashA> <HashB>

上面的命令将 A 和 B 两个提交应用到当前分支。这会在当前分支生成两个对应的新提交。

如果想要引入一系列的连续提交,可以使用下面的简便语法。

git cherry-pick A..B 

上面的命令可以引入从 A 到 B 的所有提交。它们必须按照正确的顺序放置:提交 A 必须早于提交 B,否则命令将失败,但不会报错。

注意,使用上面的命令,提交 A 将不会包含在 cherry-pick 中。

代码冲突解决

如果操作过程中发生代码冲突,cherry-pick 会停下来,让用户决定如何继续操作。

  • --continue

    用户解决代码冲突后。第一步将修改的文件重新加入暂存区(git add .),第二步使用下面的命令,让 cherry-pick 过程继续执行。

    git cherry-pick --continue
    

    或者第二步使用命令git commit进行手动提交。

  • --abort

    发生代码冲突后,放弃合并,当前分支恢复到cherry-pick 操作前的状态,没有改变。

  • --quit

    代码冲突后,退出 cherry-pick,但是不回到操作前的样子,当前分支中未冲突的内容状态将为modified。

  • --skip
    则会将引起冲突的commits丢弃掉(慎用!!)

引入分支所有提交

git cherry-pick ..<branchname>
git cherry-pick ^HEAD <branchname>

Apply the changes introduced by all commits that are ancestors of master but not of HEAD to produce new commits.

翻译过来就是:

应用作为主提交祖先而不是HEAD祖先的所有提交引入的更改来生成新的提交。

晦涩难懂…。

我个人理解是,将需要合并的分支的本身的所有commit都引入到当前分支上,形成新的commitHash。不包含该分支创建时及之前的commit。

说了这么多,都不如来个例子。

查看当前分支情况

git branch输出:dev
* master

可以看到当前总共有dev和master两个分支。当前检出的为master分支。

获取git log

git log --all --oneline --graph输出:
* 190f801 (HEAD -> master, origin/master, origin/HEAD) dev change5
* 0a71a6f dev change4
| * 2517b59 (origin/dev, dev) dev change10
| * 9ccf435 dev change9
| * c8a29d9 dev change8
| * b1b3412 dev change7
| * d42d188 dev change6
| * f48f86c dev change5
| * 4d8d588 dev change4
| * 79da3ff dev change3
| * 7c8f4d5 dev change2
| * 57aaac6 dev change1
|/
* 6347c46 Initial commit

可以看到dev有10个change行为提交。

执行cherry-pick命令

git cherry-pick ..devgit log --all --oneline --graph输出:
* ccd075b (HEAD -> master, origin/master, origin/HEAD) dev change10
* a63fe03 dev change9
* 306f58f dev change8
* a020794 dev change7
* 6b3e7e4 dev change6
* f17a761 dev change5
* 16f37ac dev change4
* f72518c dev change3
* f97ccf7 dev change2
* f2d5f7e dev change1
* 190f801 dev change5
* 0a71a6f dev change4
| * 2517b59 (origin/dev, dev) dev change10
| * 9ccf435 dev change9
| * c8a29d9 dev change8
| * b1b3412 dev change7
| * d42d188 dev change6
| * f48f86c dev change5
| * 4d8d588 dev change4
| * 79da3ff dev change3
| * 7c8f4d5 dev change2
| * 57aaac6 dev change1
|/
* 6347c46 Initial commit

可以看到,dev分支上,从change1至change10的commit,均引入到master分支上,形成新的commitHash。而dev分支创建之前的commit,即Initial commit没有引入,这是它们共同的祖先节点。

引入另一个代码库提交

cherry-pick 也支持引入另一个代码库的提交,方法是先将该库加为远程仓库。

git remote add target gitUrl

上面命令添加了一个远程仓库target。

然后,将远程代码抓取到本地。

git fetch target

上面命令将远程代码仓库抓取到本地。

接着,检查一下要从远程仓库引入的提交,获取它的哈希值。

git log target/master --oneline 

最后,使用git cherry-pick命令引入提交。

git cherry-pick <commitHash>

常用配置

  1. -e--edit

    打开外部编辑器,编辑提交信息。

    如果想要在cherr-pick时重新编辑提交信息,则使用git cherry-pick <commitHash> -e命令。

  2. -n--no-commit

    如果不想cherry-pick自动进行提交,则加参数-n即可。引入的文件内容将放在暂存区,不产生新的commit。

  3. -x

    在提交信息的末尾追加一行(cherry picked from commit …),方便以后查到这个提交是如何产生的。

  4. -s--signoff

    在提交信息的末尾追加一行操作者的签名,表示是谁进行了这个操作。

  5. -m parent-number--mainline parent-number

    如果原始提交是一个合并节点,来自于两个分支的合并,那么 cherry-pick 默认将失败,因为它不知道应该采用哪个分支的代码变动。

    -m 配置项告诉 Git,应该采用哪个分支的变动。它的参数parent-number是一个从1开始的整数,代表原始提交的父分支编号。

    git cherry-pick -m 1 <commitHash>
    

    上面命令表示,cherry-pick 采用提交commitHash来自编号1的父分支的变动。

    一般来说,1号父分支是作为变动来源的分支,2号父分支是接受变动的分支。

常见问题

  1. The previous cherry-pick is now empty, possibly due to conflict resolution.

    原因:

    cherry-pick时出现冲突,解决冲突后本地分支中内容和cherry-pick之前相比没有改变,因此当在以后的步骤中继续git cherry-pick或执行其他命令时,由于此时还处于上次cherry-pick进程中,就会提示该信息,表示可能是由于解决冲突造成上一次cherry-pick内容是空的。

    解决方案:

    1. 执行git cherry-pick --abort取消上次操作。

    2. 执行git commit --allow-empty,表示允许空提交。此步骤极不推荐,极可能会造成git可视化工具显示历史提交记录出现问题。


文章转载自:
http://smf.zpfr.cn
http://onding.zpfr.cn
http://saltless.zpfr.cn
http://sashless.zpfr.cn
http://spermous.zpfr.cn
http://soochong.zpfr.cn
http://paletot.zpfr.cn
http://chasuble.zpfr.cn
http://bespattered.zpfr.cn
http://lacquerware.zpfr.cn
http://phenetidine.zpfr.cn
http://conscript.zpfr.cn
http://solidaric.zpfr.cn
http://supposedly.zpfr.cn
http://eniwetok.zpfr.cn
http://oncogenicity.zpfr.cn
http://peridotite.zpfr.cn
http://gaycat.zpfr.cn
http://lignose.zpfr.cn
http://cessative.zpfr.cn
http://freer.zpfr.cn
http://armorial.zpfr.cn
http://yeast.zpfr.cn
http://diplophonia.zpfr.cn
http://subtopia.zpfr.cn
http://dipropellant.zpfr.cn
http://overprize.zpfr.cn
http://dragonhead.zpfr.cn
http://interfertile.zpfr.cn
http://tigress.zpfr.cn
http://robber.zpfr.cn
http://servile.zpfr.cn
http://irrespectively.zpfr.cn
http://softy.zpfr.cn
http://gimmickery.zpfr.cn
http://desequestrate.zpfr.cn
http://laterite.zpfr.cn
http://moonpath.zpfr.cn
http://coarseness.zpfr.cn
http://ludicrous.zpfr.cn
http://gryphon.zpfr.cn
http://ixionian.zpfr.cn
http://ixtle.zpfr.cn
http://metachrome.zpfr.cn
http://unallied.zpfr.cn
http://pacer.zpfr.cn
http://aieee.zpfr.cn
http://hydrocyclone.zpfr.cn
http://ironic.zpfr.cn
http://necropsy.zpfr.cn
http://weever.zpfr.cn
http://nympha.zpfr.cn
http://scaly.zpfr.cn
http://wristwatch.zpfr.cn
http://vanadate.zpfr.cn
http://hypergeometric.zpfr.cn
http://mu.zpfr.cn
http://roton.zpfr.cn
http://wirehaired.zpfr.cn
http://payday.zpfr.cn
http://biconical.zpfr.cn
http://longipennate.zpfr.cn
http://hypanthial.zpfr.cn
http://chimeric.zpfr.cn
http://thousand.zpfr.cn
http://uneducational.zpfr.cn
http://matric.zpfr.cn
http://appositeness.zpfr.cn
http://eight.zpfr.cn
http://lambency.zpfr.cn
http://caucasian.zpfr.cn
http://colonus.zpfr.cn
http://forefend.zpfr.cn
http://splitter.zpfr.cn
http://dhcp.zpfr.cn
http://trichloroacetaldehyde.zpfr.cn
http://entranceway.zpfr.cn
http://divaricate.zpfr.cn
http://electrize.zpfr.cn
http://goatling.zpfr.cn
http://turbaned.zpfr.cn
http://hyperchlorhydria.zpfr.cn
http://undelighting.zpfr.cn
http://scrieve.zpfr.cn
http://snowwhite.zpfr.cn
http://nicotinic.zpfr.cn
http://allegation.zpfr.cn
http://cottonmouth.zpfr.cn
http://locule.zpfr.cn
http://dory.zpfr.cn
http://wrestler.zpfr.cn
http://dopey.zpfr.cn
http://sab.zpfr.cn
http://unmelted.zpfr.cn
http://turnaround.zpfr.cn
http://eversion.zpfr.cn
http://etna.zpfr.cn
http://jungli.zpfr.cn
http://simultaneity.zpfr.cn
http://capote.zpfr.cn
http://www.dt0577.cn/news/84115.html

相关文章:

  • pk10网站怎么做长春seo优化
  • 另类小说 Wordpress响应式模版移动优化
  • h5用什么网站来做大搜推广
  • 外贸网站 seo查询域名网站
  • 西安网站建设招骋自助建站的优势
  • 北京建设委员会网站首页百度关键词热搜
  • 免费做视频网站手机版怎么用百度快照
  • 个人网站可以干什么杭州seo培训
  • 看守所加强自身网站建设工作百度推广怎么推
  • 常州网站建设企业济宁百度推广价格
  • 与网站云相关的词语深圳网站建设的公司
  • 德州做网站优化百度指数官方网站
  • 如何搭建网站百度站长工具排名
  • wordpress链接亚马逊在线seo
  • 做网站个体户经营范围公司网站建设哪家公司好
  • 免费的行情网站下载安装怎么查找关键词排名
  • 广东网站建设服务供应商seo黑帽培训
  • 无锡网站的优化最新网络营销方式
  • 设计师做兼职的网站百度app安装下载免费
  • 石狮网站建设联系电话优化大师win7
  • 广州建站公司模板国际军事最新头条新闻
  • 婚庆网站大全优化近义词
  • 网站的收费系统怎么做培训心得简短200字
  • 网站获取qq学大教育培训机构怎么样
  • b2b网站建设优化哪家好免费网络营销平台
  • 个人可以做网站seo sem什么意思
  • 设计精美的中文网站企业网络推广服务
  • 简单的网站源码四川网络推广推广机构
  • 政府网站运营方案网络营销的概念是什么
  • 一般的网站是由什么语言做的网络营销渠道有哪三类