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

Git——命令集合

Git命令集合

1. 基本操作

1.1 创建版本库
  1. 初始化本地仓库:git init
  2. 添加文件到仓库:git add | git add file file2… | git add.
  3. 提交文件到本地仓库:git commit -m “message”
1.2 版本回退
  1. 查看状态: git status
  2. 查看全部修改状态:git diff
  3. 查看指定文件修改内容:git diff
  4. 回退到指定版本:git reset --hard commit_id
  5. 回退到上一个版本:git reset --hard HEAD^
  6. 回退到上上个版本:git reset --hard HEAD^^
  7. 回退n个版本:git reset --hard HEAD~n
  8. 查看详细提交历史:git log
  9. 查看简化提交历史:git log --pretty=online
  10. 查看分支合并图:git log --graph
  11. 查看命令历史:git reflog
1.3 撤销修改
  1. 丢弃工作区的修改(未提交值暂存区):
    git checkout – file

    ​ git restore

    ​ git checkout – .

    ​ git restore .

  2. 丢弃已添加到暂存区的修改

    ​ git reset HEAD

    ​ git restore --signed

    ​ git reset HEAD .

    ​ git restore --staged

1.4 删除文件
  1. 删除未添加到暂存区的文件:

    显示将要删除的问加你和目录:git clean -n

    删除文件和目录:git clean -df

    删除文件:git clean -f git rm

2. 远程仓库

2.1 添加远程仓库
  1. 关联远程仓库:

    git remote add origin

  2. 删除远程仓库:

    git remote rm origin

  3. 查看远程仓库

    git remote -v

  4. 推送提交到远程仓库

    git push origin master #一般用于非首次推送

    git push -u origin master #-u参数是将本地master分支与远程仓库master分支关联起来,一般用于第一次推送

2.2 从远程仓库克隆
  1. git clone

3. 分支管理

3.1 创建与合并分支
  1. 查看分支:git branch
  2. 创建分支:git branch
  3. 切换分支:git checkout
  4. 创建并切换到该分支:git checkout -b
  5. 合并指定分支到当前分支:git merge
  6. 删除本地已合并分支:git branch -d
  7. 删除远程分支:git push <远程仓库名> --delete <远程分支名>
  8. 推送本地分支到远程仓库并在远程仓库创建新分支:git push <远程仓库名> <本地分支名>:<远程分支名>
3.2 解决冲突

当Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。

解决冲突就是把Git合并失败的文件手动编辑为我们希望的内容,再提交。

查看分支合并图:

git log --graph

冲突的产生一般都是这两种情况:

  • 远程仓库的代码落后于本地仓库
  • 远程仓库的代码远超本地仓库

说明

冲突是如何表示的:

​ 当产生合并冲突时,该部分会以 <<<<<<< , ======= 和 >>>>>>> 表示。在 ======= 之前的部分是当前分支这边的情况,在 ======= 之后的部分是传入分支的情况。

如何解决冲突

在看到冲突以后,你可以选择以下两种方式:

  • 决定不合并。这时,唯一要做的就是重置 index 到 HEAD 节点。 git merge --abort 用于这种情况。
  • 解决冲突。 Git 会标记冲突的地方,解决完冲突的地方后使用 git add 加入到 index 中,然后使用 git commit 产生合并节点。

你可以用以下工具来解决冲突:

  • 使用合并工具。 git mergetool 将会调用一个可视化的合并工具来处理冲突合并。
  • 查看差异。 git diff 将会显示三路差异(三路合并中所采用的三路比较算法)。
  • 查看每个分支的差异。 git log --merge -p 将会显示 HEAD 版本和 MERGE_HEAD 版本的差异。
  • 查看合并前的版本。 git show :1:文件名 显示共同祖先的版本, git show :2:文件名 显示当前分支的 HEAD 版本, git show :3:文件名 显示对方分支的MERGE_HEAD 版本。
3.3 Bug分支
  1. 暂存工作区状态:git stash
  2. 查看暂存的工作区状态:git stash list
  3. 恢复全部暂存状态,但不删除暂存内容:git stash apply
  4. 恢复指定暂存状态,但不删除暂存内容:git stash apply stash@{}
  5. 删除暂存内容:git stash drop
  6. 恢复暂存状态,同时删除暂存内容:git stash pop
  7. 复制一个特定的提交到当前分支:git cherry-pick <commit_id>

说明

修复bug时,我们会通过创建新的bug分支进行修复,然后合并,最后删除;

当手头工作没有完成时,先把工作现场 git stash 一下,然后去修复bug,修复后,再 git stash pop

在master分支上修复的bug,想要合并到当前dev分支,可以用 git cherry-pick <commit_id> 命令,把bug提交的修改“复制”到当前分支

3.4 Feature分支
  1. 强制删除分支(会丢失分支上的修改):git branch -D

说明

开发一个新feature,最好新建一个分支;

如果要丢弃一个没有被合并过的分支,可以通过 git branch -D 强行删除。

3.5 多人协作
  1. 查看远程仓库信息:git remote

  2. 查看远程仓库详细信息:git remote -v

  3. 与远程仓库代码同步:git pull # git pull = git fetch + git merge

  4. 在本地创建和远程分支对应的分支:

    git checkout -b branch-name origin/branch-name

    git switch -c branch-name origin/branch-name

  5. 将本地分支与远程仓库关联:git branch --set-upstream-to origin/

  6. 推送本地分支到远程仓库:git push origin

3.6 Rebase变基
  1. 变基(衍合):git rebase
  2. 放弃变基:git rebase --abort
  3. 解决冲突之后继续变基:git rebase --continue

说明

rebase操作可以把本地未push的分叉提交历史整理成直线;

rebase的目的是使得我们在查看历史提交的变化时更容易,因为分叉的提交需要三方对比。

4.标签管理

4.1 创建标签
  1. 新建标签(指向最新的commit_id):git tag <tag_name>
  2. 新建标签(指向特定commit_id):git tag <tag_name> <commit_id>
  3. 查看所有标签:git tag
  4. 显示某个标签的详细信息:git show <tag_name>
  5. 新建带有说明的标签:git tag -a <tag_name> -m “说明” <commit_id>
4.2 操作标签
  1. 删除指定本地标签:git tag -d <tag_name>
  2. 删除指定远程标签:git push origin :refs/tags/<tag_name>
  3. 推送一个本地标签:git push origin <tag_name>
  4. 推送全部未推送过的本地标签:git push origin --tags

5.git场景处理

5.1 fatal: refusing to merge unrelated histories

有时在pull或merge时会出现下述错误:

fatal: refusing to merge unrelated histories

解决办法:

git merge origin/master *--allow-unrelated-histories*

结果如下:

$ git merge origin/master *--allow-unrelated-histories*
Already up to date!
Merge made by the 'recursive' strategy.

只需要在命令的最后面添加 --allow-unrelated-histories ,这句话是告诉Git允许不相关历史合并

5.2 git merge origin master与merge origin/master

git merge origin mastergit merge origin/master的区别

# 将origin merge 到 master 上
git merge origin master# 将origin上的master分支 merge 到当前 branch 上
git merge origin/master

相关文章:

Git——命令集合

Git命令集合 1. 基本操作 1.1 创建版本库 初始化本地仓库&#xff1a;git init添加文件到仓库&#xff1a;git add | git add file file2… | git add.提交文件到本地仓库&#xff1a;git commit -m “message” 1.2 版本回退 查看状态&#xff1a; git status查看全部修改…...

python 数据可视化折线图练习(下:代码演示)

根据上篇对三国疫情情况数据的罗列&#xff0c;构建折线图完成数据展示。&#xff08;示例如下&#xff09; 接下来是具体代码演示 import json from pyecharts.charts import Line from pyecharts.options import TitleOpts , LegendOpts , ToolboxOpts ,VisualMapOpts , T…...

深入探索 Go 1.18 的 debug/buildinfo:构建信息的获取与应用

标题&#xff1a;深入探索 Go 1.18 的 debug/buildinfo&#xff1a;构建信息的获取与应用 引言 Go 语言自 1.18 版本起&#xff0c;引入了对构建信息的标准化处理&#xff0c;这一特性极大地简化了获取程序构建信息的过程。debug/buildinfo 包提供了访问 Go 二进制文件中嵌入…...

Nios II的BSP Editor

1.菜单打开BSP Editor &#xff08;1&#xff09; &#xff08;2&#xff09; &#xff08;3&#xff09; 项目文件夹 -> software文件夹 -> ... _bsp文件夹 -> settings.bsp文件 2.文件打开BSP Editor 选中项目文件&#xff0c;右键&#xff0c;Nios II -> …...

Android-自适用高度的ViewPager

需求 在项目中&#xff0c;我们常常遇到需要动态调整 ViewPager 的高度&#xff0c;以适应其内容大小的需求。默认情况下&#xff0c;ViewPager 的高度是固定的&#xff0c;无法根据每个页面的内容高度进行调整。这会导致在内容高度不一致时&#xff0c;出现不必要的空白区域或…...

代码随想录day38|| 322零钱兑换 279完全平方数 139单词拆分

322零钱兑换 力扣题目链接 题目描述&#xff1a; 给你一个整数数组 coins &#xff0c;表示不同面额的硬币&#xff1b;以及一个整数 amount &#xff0c;表示总金额。 计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额&#xff0c…...

Cesium天空盒子(Skybox)制作(js代码)和显示

介绍 在Cesium中&#xff0c;星空背景是通过天空盒子方式&#xff08;6张图片&#xff09;来显示的&#xff0c;原生的图片分辨率太低&#xff0c;本项目用于生成天空盒子的6张图片。最终生成的6个图片大小约为500kb(每个)&#xff0c;格式为jpg&#xff0c;总共的恒星数目约为…...

JAVA中的缓冲流BufferedInputStream

在Java中&#xff0c;BufferedInputStream 是一种用于包装其他输入流&#xff08;如 FileInputStream&#xff09;的过滤流。它通过内部缓冲区机制提高了输入流处理的效率。使用缓冲流可以减少读取数据的次数&#xff0c;因为每次从输入流读取数据时&#xff0c;BufferedInputS…...

WindowContainerTransaction类详解(一)

1、WindowContainerTransaction是什么&#xff1a; windowContainerTransaction类的对象是用来存储对windowContainer的修改的一个集合&#xff0c;windowContainer。因为应用侧是无法直接操作windowContainer的&#xff0c;如果应用侧需要修改windowContainer的话&#xff0c…...

安装NFS扩展

#添加helm源 helm repo add nfs-subdir-external-provisioner https://kubernetes-sigs.github.io/nfs-subdir-external-provisioner #创建个namespace(可选,主要是为了查看资源方便) kubectl create ns nfs-sc-default #使用helm安装(10.1.129.86为NFS地址,/home/data/nfs…...

计算机网络——运输层(进程之间的通信、运输层端口,UDP与TCP、TCP详解)

运输层协议概述 进程之间的通信 运输层向它上面的应用层提供通信服务。 当网络边缘部分的两台主机使用网络核心部分的功能进行端到端的通信时&#xff0c;都要使用协议栈中的运输层&#xff1b;而网络核心部分中的路由器在转发分组时只用到下三层的功能。 Q1&#xff1a;我们…...

代码随想录算法训练营第一天 | 二分查找

文章目录 Leetcode704 二分查找二分法的使用前提:区间选择其他注意事项 Leetcode27 移除元素解题思路:优化思路 Leetcode704 二分查找 链接&#xff1a;https://leetcode.cn/problems/binary-search/ 代码随想录: https://programmercarl.com/ 时间复杂度: O(logN) 空间复杂度:…...

python相关知识

1、注释 共有三种&#xff1a;#、 、””” ””” 2、数据类型 整数、浮点、字符串、布尔、列表、元组、集合、字典 num1 666、num2 3.14、t1 True、t2 False、 列表&#xff1a;list [1,2,3,4] 元组&#xff1a;tuple (11,aaa,ddd,3) 字典&#xff1a;dict {li…...

Visual Studio 2022 LNK2001无法解析的外部符号 _wcscat_s 问题记录

ANSI C程序中&#xff0c;用到了wcsrchr、wcsncpy_s、wcscat_s、wcscpy_s等几个字符串函数&#xff0c;但是编译时提示&#xff1a; 错误 LNK2001 无法解析的外部符号 _wcscat_s 查了挺多帖子&#xff0c;没有解决。 https://bbs.csdn.net/topics/250012844 解决VS编译…...

Java高并发处理机制

高并发处理的思路&#xff1a; 扩容&#xff1a;水平扩容、垂直扩容缓存&#xff1a;将基础的数据放入缓存进行处理使用SpringCloud的注册中心&#xff0c;分服务注册到同一个注册中心&#xff0c;服务器检测使用Spring的熔断操作&#xff0c;检测服务器的心跳那个正常随机跳转…...

7 数据存储单位,整型、浮点型、字符型、布尔型数据类型,sizeof 运算符

目录 1 数据类型的分类 2 数据存储单位 2.1 位 2.2 字节 2.3 其余单位 3 整数类型 3.1 基本介绍 3.2 整型的类型 3.2.1 整数类型多样性的原因 3.2.2 整型类型之间的相对大小关系 3.3 整型注意事项 3.4 字面量后缀 3.5 格式占位符 3.6 案例&#xff1a;声明并输出…...

导游职业资格考试真题题库

导游职业资格考试真题题库 80.重庆有"雾都"之称。壁山区的()全年雾日多204天&#xff0c;堪称"世界之最"。 A.枇杷山 B.雾灵山 C.云雾山 D.四姑娘山 答案&#xff1a;C 81.我国最具热带海洋气候特色的地方为&#xff08;&#xff09;。 A.广西壮族…...

【Rust】使用开源项目搭建瓦片地图服务

本文通过获取在线和离线地图数据&#xff0c;使用开源Rust项目搭建瓦片地图服务&#xff0c;并使用DevExpress的MapControl控件使用自建地图服务 获取地图数据 获取地图数据有很多种方式&#xff0c;这里分别用在线和离线地图数据举例说明 在线下载瓦片地图 打开在线瓦片地…...

【面试宝典】mysql常见面试题总结(上)

一、MySQL 中有哪几种锁&#xff1f; MySQL中的锁机制是数据库并发控制的重要组成部分&#xff0c;它用于管理多个用户对数据库资源的访问&#xff0c;确保数据的一致性和完整性。MySQL中的锁可以根据不同的分类标准进行分类&#xff0c;以下是一些常见的分类方式及对应的锁类…...

第1章 初识C语言

第1章 初识C语言 1.1 C语言概述 1.1.1 C语言的发展历史 C语言的原型为ALGOL 60语言&#xff08;也称A语言&#xff09;。 1963年 剑桥大学将ALGOL 60语言发展成为GPL语言。 1967年 剑桥大学的Matin Richards简化GPL&#xff0c;产生了BGPL语言。 1970年 美国贝尔实验室的Ken…...

【考研数学】定积分应用——旋转体体积的计算(一文以蔽之)

目录 一、如何计算旋转体体积&#xff1f;思考一个小例子 二、旋转体体积的二重积分表达式 三、用真题&#xff0c;小试牛刀 定积分的应用中&#xff0c;有一类题是求解旋转体的体积问题。 相较于记忆体积计算公式&#xff0c;有一种通法求解体积更不容易出错&#xff1a;二重…...

PHP移动端商城分销全平台全端同步使用

&#x1f4f1;【掌中购物新纪元&#xff1a;探索移动端购物商城系统的无限魅力】&#x1f6cd;️ &#x1f680; 随时随地&#xff0c;购物自由新体验 在这个快节奏的时代&#xff0c;移动端购物商城系统彻底颠覆了传统购物方式&#xff0c;让消费者享受到了前所未有的便捷与…...

TLE8386-2EL:汽车级DC-DC转换器中文资料书

描述 TLE8386-2EL是一款具有内置保护功能的低端感应升压控制器。该器件的主要功能是将输入电压升高&#xff08;升压&#xff09;到更大的输出电压。开关频率可从100kHz调整至700kHz&#xff0c;并可与外部时钟源同步。 TLE8386-2EL的独特功能可将关断电流消耗降至 <2μA。该…...

EasyRecovery17中文mac苹果电脑版数据恢复软件 永久免费破解版下载

&#x1f389; 数据丢失不再是噩梦&#xff01;EasyRecovery17中文版来拯救你的硬盘啦&#xff01; 各位小伙伴们&#xff0c;有没有遇到过重要文件一不小心就消失无踪的尴尬情况&#xff1f;别担心&#xff0c;今天就给大家种草一款神奇的工具——EasyRecovery17中文版&#x…...

Ubuntu 22.04 安装 VirtualBox7

Ubuntu默认库为VirtualBox-6版本 # 安装 VirtualBox-6 sudo apt update sudo apt install virtualbox# 卸载 VirtualBox-6 sudo apt remove --purge --auto-remove virtualbox virtualbox-6.1 1. 安装 VirtualBox-7 # 导入软件包密钥 curl https://www.virtualbox.org/downl…...

NPM使用教程:从入门到精通

NPM使用教程&#xff1a;从入门到精通&#xff0c;掌握Node.js包管理神器 引言 随着Node.js的流行&#xff0c;JavaScript已经成为服务器端开发的主力军。NPM&#xff08;Node Package Manager&#xff09;作为Node.js的官方包管理工具&#xff0c;为开发者提供了一个庞大的代…...

模电实验3 - 单电源集成运放交流耦合放大器

实验目标 学习集成运放的单电源使用。掌握交流耦合单电源集成运放放大器的测试方法。了解交流耦合单电源集成运放放大器的特点。 实验器材 ADALM2000 1kΩ 电阻 (1/4 W) x 1 10 kΩ 电阻 (1/4 W) x 1 100kΩ 电阻 (1/4 W) x 3 0.1μF电容 x 1 1μF电容 …...

海对外经贸大学学报

《上海对外经贸大学学报》创刊于1994年&#xff0c;原名为《世界贸易组织动态与研究》(上海对外贸易学院学报)&#xff0c;随原上海对外贸易学院更名为上海对外经贸大学&#xff0c;自2014年起更为现名&#xff0c;现为综合性社科类双月刊&#xff0c;为中文社会科学引文检索&a…...

数字化营销在公域场景中的无限可能

在如今的商业领域&#xff0c;公域场景为企业提供了广阔的发展空间&#xff0c;而数字化营销则成为了企业在这些场景中脱颖而出的关键利器。 ​ 一、电商平台营销 当企业在淘宝、京东等大型电商平台开设店铺&#xff0c;数字化营销便开始大显身手。 企业不仅能踊跃参与像双十…...

聚观早报 | 一加13配置细节曝光;谷歌首推人工智能手机

聚观早报每日整理最值得关注的行业重点事件&#xff0c;帮助大家及时了解最新行业动态&#xff0c;每日读报&#xff0c;就读聚观365资讯简报。 整理丨Cutie 8月15日消息 一加13配置细节曝光 谷歌首推人工智能手机 MONA M03汽车即将上市 iPhone SE 4将升级8GB运行内存 R…...