常用的Git便捷操作合集

目录
  • 1.Fork出来的Git仓库同步代码
  • 2.合并多个提交
  • 3.代码回退
  • 4.使用worktree
  • 5.其它

1.Fork出来的Git仓库同步代码

背景:有的时候从原仓库fork出了一个新仓库,这个新仓库做了自己的修改。可是原仓库也进行了更新,比如修复了bug,增加了新特性之类的。这个时候想要把原仓库代码同步过来。

原理:把原仓库的代码拉到本地,然后通过git merge把原仓库分支代码合到自己的分支代码。

1.先拉取原仓库代码到本地

git remote add upstream (填写你仓库git地址)

git fetch upstream

这样就把原仓库代码拉到本地了,而且 upstream 跟原仓库进行了绑定。(类似origin的绑定,upstream 也可以命名为其它的名称)

此时执行git remote,会看到有两个:

origin
remote

2.合并分支

切换到fork仓库的分支,可以新建一个合并分支。然后执行命令:

# 分支名不一定得是master,也可以是其它的原仓库分支。
git merge upstream/master

如果有冲突就要解决冲突,解决完执行下命令即可:

git merge --continue

最后,如果完成了,可以执行命令移除这个绑定。

git remote remove upstream

2.合并多个提交

完成一小部分功能进行提交是一个良好的习惯,有利于我们随时回溯代码。然而整体功能没完成是不能提交到主干的,而且也倾向于整体功能完成合并为一个提交。因此本地的多个小提交合并成一个提交就很有必要了。下面举个栗子演示合并操作。

执行git log,查看历史提交:

commit 03c72b6dfc24c6bf6f60e2c922552249cc3e5376

git test 3

commit 24276fbd0495c4b337f4058726a48e68118eac0a

git test 2

commit 9f92d8624a3adf7cd6fb69268f99d864390838c4

git test 1

假设要将前两笔提交合并,则记录下第三笔的commitId:9f92d8624a3adf7cd6fb69268f99d864390838c4。(第三笔提交不参与合并)

执行以下命令:

git rebase -i 9f92d8624a3adf7cd6fb69268f99d864390838c4

执行后会弹出以下:

pick 24276fbd git test 2

pick 03c72b6d git test 3

# 省略以下内容

此时要将除第一个外的pick改为squash或者s。即改完后为:

pick 24276fbd git test 2

s 03c72b6d git test 3

# 省略以下内容

改完保存退出,会弹出commit message修改界面,修改保存即可。

再执行git log发现提交已经合并了。

commit 980d318f91f2faa1d748ae5a963b692162dd521c

git test merge

commit 9f92d8624a3adf7cd6fb69268f99d864390838c4

git test 1

3.代码回退

1、在工作区的代码

# 丢弃某个文件
git checkout -- 文件名

# 丢弃全部
git checkout -- .

2、git add到了索引区

# 回退索引区所有文件
git reset HEAD .

# 回退索引区指定文件夹
git reset HEAD 文件夹名

3、commit 到本地分支的代码

# 回退最新一笔提交
git reset --hard HEAD^

# 回退到指定的版本
git reset --hard 版本号

这里说下reset时,指定--hard、--soft、--mixed的区别:

  • hard: 回退时HEAD指针被回退,索引区、工作目录都被重置了。
  • soft: 只改变了历史提交(HEAD指针),索引区和工作目录没有更改。
  • mixed: 不指定时默认为mixed,改变了历史提交(HEAD指针),重置了索引区。

4.使用worktree

当你的项目很大,而有多个特性需要开发时,为了避免频繁切换分支,可以使用git worktree

git worktree非常适合大型项目又需要维护多个分支,想要避免来回切换的场景。其有以下几个优点:

  • 单独 clone 项目相比,节省了硬盘空间,又因为 git worktree 使用 hard link 实现,要远远快于 clone
  • 提交可以在同一个项目中共享
  • 可以快速进行并行开发,同一个项目多个分支同时并行演进

git worktree使用非常简单,掌握3个命令即可:

# 添加一个 worktree。
git worktree add filePath
# 移除一个 worktree
git worktree remove filePath
# 查看目前所有的 worktree
git worktree list

创建了worktree后,只需要用IDE打开添加到filePath的项目即可。

5.其它

#本地分支与远程进行关联
git branch --set-upstream-to=origin/(要关联的分支名)

#推送本地新建分支到远端分支(远端会自动创建分支)
git push origin newbranch:originbranch

#删除远端分支
git push origin --delete (branch_name)

#查看本地分支关联的远程分支
git branch -vv

#分支重命名
git branch -m oldName newName

#修改当前项目的用户名和邮箱
git config --local user.name “userName"
git config --local user.email email@example.com

#删除本地版本库上那些失效的远程追踪分支:
git remote prune origin --dry-run

以上就是常用的Git便捷操作合集的详细内容,更多关于Git便捷操作的资料请关注我们其它相关文章!

(0)

相关推荐

  • Git创建子分支,合并分支并提交

    Git合并分支后,需要将子分支提交到git仓库,这个时候就需要单独提交子分支,其步骤如下: 1.先创建子分支,并包含最新当前分支下的修改数据 git checkout -b sonBranch 2.将新分支内容全部提交 git add . git commit -m "完成开发" 3.在码云创建一个子分支 git push -u origin sonBranch 4.切换到主分支 git checkout master 5.合并分支,更新主分支内容 git merge sonBranc

  • git fork同步是什么意思?

    官方文档:http://help.github.com/fork-a-repo/ 概要: 克隆别人的代码库到自己的项目中,可以作为子模块的形式使用,或二次开发 操作流程: 在开源项目中点击fork按钮,稍等一会儿,该项目便会拷贝一份到你的respositories中,克隆一份代码到本地:git clone git@github.com:username/Spoon-Knife.git 配置:(项目克隆完成后,默认远程的别名为origin,此为我们自己项目中的版本,并非原始作者的代码库) 创建原始

  • Git回退代码到某次commit的实现方法

    前言 工作中,Git的使用越来越频繁..除了最常用的clone,add,commit,push,pull等命令:还有回退命令reset.这一篇博客就记录一下该回退命令的简单使用. 场景 因为公司开发过程中,处理订单,限时购买等业务时,都是用的阿里云的消息队列MQ实现的.或者是两个系统之间的交互,同步信息,如用户在支付系统A下了一个订单(支付成功),这个时候支付系统A除了处理订单,还有向库存系统B发送一个消息,告知库存系统B要减少下单商品的库存. 我本地跑项目的时候,如果不注释掉监听器,测试服上的

  • git rebase -i合并多次提交的实现

    简介 在日常开发中,代码变更比较频繁,有时候想让前几次提交的合并为一次提交,这里可以使用git rebase -i 命令来完成,当然,git rebase命令不仅仅用于合并提交,它还有许多用处,比如可以使用git rebase onto将某一段commit粘贴到另一个分支上等等,这里主要介绍合并提交. 命令介绍 rebase为变基 git rebase -i 命令可以压缩合并多次提交 格式:git rebase -i [startpoint] [endpoint] 其中-i的意思是–intera

  • 45个GIT经典操作场景使用详解

    目录 正文 我刚才提交了什么? 我的提交信息(commit message)写错了 我提交(commit)里的用户名和邮箱不对 我想从一个提交(commit)里移除一个文件 我想删除我的的最后一次提交(commit) 删除任意提交(commit) 我尝试推一个修正后的提交(amended commit)到远程,但是报错: 我意外的做了一次硬重置(hard reset),我想找回我的内容 暂存(Staging) 我需要把暂存的内容添加到上一次的提交(commit) 我想要暂存一个新文件的一部分,而

  • git工具常用命令及ssh操作方法

    目录 git基础命令 暂存,本地仓库,远程仓库,本地代码 拉取其他分支 合并分支 代码提交 版本穿梭 注意点 SSH git基础命令 git clone '远程仓库地址' 第一次从仓库拉取代码 git pull  拉取最新 git add . 把代码提交到暂存区git commit -m "备注"  将暂存区内容添加到本地仓库 git push  提交 git checkout '分支名'  切换到指定分支名 git branch  查看本地分支列表 git branch -a/–al

  • Git获取本地仓库及基础操作指令总结

    目录 一.Git获取本地仓库 二.Git基础操作指令 1.查看修改的状态(status) 2.添加工作区到暂存区(add) 3.提交暂存区到本地仓库(commit) 4.查看提交日志(log) 5.版本回退 6.添加文件至忽略列表 知识点补充 一.Git获取本地仓库 要使用Git对我们的代码进行版本控制,首先需要获得本地仓库 1.在电脑任意的磁盘位置创建一个空目录(例如test)作为我们的本地Git仓库 2.进入这个目录中,点击右键打开Git bash窗口 3.执行命令git init 4.如果

  • 常用的Git便捷操作合集

    目录 1.Fork出来的Git仓库同步代码 2.合并多个提交 3.代码回退 4.使用worktree 5.其它 1.Fork出来的Git仓库同步代码 背景:有的时候从原仓库fork出了一个新仓库,这个新仓库做了自己的修改.可是原仓库也进行了更新,比如修复了bug,增加了新特性之类的.这个时候想要把原仓库代码同步过来. 原理:把原仓库的代码拉到本地,然后通过git merge把原仓库分支代码合到自己的分支代码. 1.先拉取原仓库代码到本地 git remote add upstream (填写你仓

  • 常用的js方法合集

    数组及对象深拷贝 var arr = [1,'2',{a:1,b:[1,2]}]; function deepCopy(p, c) { var c = c || {}; for (var i in p) { if (typeof p[i] === 'object' && p[i] !== null) { c[i] = (p[i].constructor === Array) ? [] : {}; deepCopy(p[i], c[i]); } else { c[i] = p[i]; } }

  • Python字符串和其常用函数合集

    目录 1.字符串定义 2.首字母大写 3.所有字母大写 4.所有字母小写 5.大小写颠倒 6.填充0至指定长度 7.统计字符串中某个成员的个数 8.字符串是否以某个成员开头或结尾 9.查找子串在主串中第一次出现的位置 10.字符串过滤 11.字符串替换 12.字符串的is函数 13.字符串切片 1.字符串定义 # coding:utf-8 if __name__ == '__main__':     '''      通过单引号定义      通过三个单引号定义      通过三个双引号定义  

  • Windows常用脚本合集(推荐)

    目录 Windows 常用脚本合集 1.问题描述 2.软硬件描述 3.使用方法 4.常用shell Windows 常用脚本合集 1.问题描述 因为使用windows一些常用命令需要手动操作,比如启用ssh链接,要先使用win+r输入cmd再输入ssh,有时候甚至ssh命令容易忘记,还需要查看帮助,所以特此集合了一些常用命令 2.软硬件描述 操作系统windows10 笔记本电脑 3.使用方法 创建文件xx.bat再[常用shell]中把代码复制到xx.bat中保存即可,然后双击使用 4.常用s

  • 详解R语言plot函数参数合集

    最近用R语言画图,plot 函数是用的最多的函数,而他的参数非常繁多,由此总结一下,以供后续方便查阅. plot(x, y = NULL, type = "p", xlim = NULL, ylim = NULL, log = "", main = NULL, sub = NULL, xlab = NULL, ylab = NULL, ann = par("ann"), axes = TRUE, frame.plot = axes, panel.

  • Java8 Stream 流常用方法合集

    目录 一.概述 二.分类 三.具体用法 1. 流的常用创建方法 2. 流的中间操作 3. 流的终止操作 一.概述 Stream 是 Java8 中处理集合的关键抽象概念,它可以指定你希望对集合进行的操作,可以执行非常复杂的查找.过滤和映射数据等操作.使用Stream API 对集合数据进行操作,就类似于使用 SQL 执行的数据库查询.也可以使用 Stream API 来并行执行操作. 简而言之,Stream API 提供了一种高效且易于使用的处理数据的方式. 特点: 不是数据结构,不会保存数据.

  • PHP常见算法合集代码实例

    许多人都说 算法是程序的核心,一个程序的好于差,关键是这个程序算法的优劣,下面是一些常用的算法和实例,大家可以好好学习下 一.文件夹遍历 <?php function allFile($path = __DIR__, $level = 1) { if (is_dir($path) && is_readable($path)) { if($pd = opendir($path)) { while (($file = readdir($pd)) !== false) { if($file

  • 2022最新前端常见react面试题合集

    目录 react性能优化方案 什么是 React Context? 何为 JSX props 是什么 应该在 React 组件的何处发起 Ajax 请求 react 强制刷新 使用 React Hooks 好处是啥? Redux内部原理 内部怎么实现dispstch一个函数的 何为纯函数(pure function) 如何配置 React-Router 实现路由切换 在 React 中,何为 state react16版本的reconciliation阶段和commit阶段是什么 类组件和函数组

  • 基于apicloudAJAX请求代码合集

    get请求代码: api.ajax({ url:'http://m.weather.com.cn/data/101010100.html' //天气预报网站的WebService接口 },function(ret,err){ if (ret) { api.alert({msg:JSON.stringify(ret)}); } else { api.alert({msg:JSON.stringify(err)}); }; }); POST请求-Form表单提交: api.ajax({ url: '

  • Vim命令合集

    命令历史 以:和/开头的命令都有历史纪录,可以首先键入:或/然后按上下箭头来选择某个历史命令. 启动vim 在命令行窗口中输入以下命令即可 vim 直接启动vim vim filename 打开vim并创建名为filename的文件 文件命令 打开单个文件 vim file 同时打开多个文件 vim file1 file2 file3 ... 在vim窗口中打开一个新文件 :open file 在新窗口中打开文件 :split file 切换到下一个文件 :bn 切换到上一个文件 :bp 查看当

随机推荐