Git中常见的一些问题总结

1、git添加到暂存区的修改,如果不想要了,怎么撤销

模拟使用一下这种场景:

新增了两个文件:f.txt和g.txt

然后提交到暂存区:

可以选择文件批量添加到暂存区中来。如上所述

此时颜色发生改变,表示存储到了暂存区。

但是如果此时此刻想把文件从暂存区中移出来,那么如何操作?

选择还原之后,可以看到依然是普通的文件,但是文件依然存在于工作目录下。

对应的git命令参考:https://blog.csdn.net/danniyedan/article/details/122695361

2、git添加到本地仓库,如果不想要了,怎么撤销

此时此刻已经回退到了未添加到暂存区之前的状态。

3、提交代码时发现别人已经提交了(没有代码冲突),此时需要重新拉取文件

同时在目录下创建c.txt和c.txt文件,各自修改各自的。

先提交c.txt,再提交b.txt;在提交b.txt的时候,出现了异常信息

那么需要首先进行拉取

拉取后会显示已经添加了c.txt文件

但是这个时候,自己提交的b.txt文件还需要推送到远程。

点击推送即可。

然后另外一个开发者想要拉取得到最新添加的b.txt文件,也需要重复上面的操作流程。

这也是开发人员最常用的方式:每天早上过来的时候,首先拉取一下最新的代码,然后在此基础上进行修改代码。

4、提交代码时发现别人已经提交且存在代码冲突,此时需要重新拉取文件、解决冲突,重新提交

接着上面所说,如果多个开发者同时修改的是同一个文件的情况,这个时候将会造成代码冲突。

假如两个人同时修改了b.txt文件,A先提交,那么对于A来说,是没有问题的;而在B提交的时候因为没有拉取最新提交的代码,就会遇到问题

那么这个时候,首先应该去拉取获取得到最新的文件信息。

依然会出现下面的问题。但是可以发现b.txt文件已经出现了感叹号了!

说明了存在着代码冲突,所以需要来解决冲突。我们不必做其他的事情,只需要在点击关闭的时候,会弹出一个窗口,如下:

然后会进入到一个窗口(会有提示窗口,点击确定即可)

那么展示出来的窗口如下所示:

只需要重点关注下上面标红的框框,以及显示的文字上面即可。

这里比较简单了!只需要做些操作即可。

修改完成之后,需要将当前冲突修改为“标记为已解决”,然后保存即可。

然后发现状态为已经修改,只需要再次提交即可。

提交的过程中,可以看到代码自动的给我们添加了注释,说明是修改了哪些代码冲突

然后确定完成之后,推送到远程仓库中去。

5、版本回退

如果某个版本不符合我们的预期,我们可以采取回退的方式。

在小乌龟中是最好操作的。

现有的版本:

加入说我们想要回退到第一次修改b.txt文件的地方,那么应该如何来进行操作?

然后选择

因为我想回退到只有第一次在b.txt中新增文字的地方,所以我选择Hard模式。

最终达到了目的

Soft、Mixed和Hard模式的区别

参考文章:https://blog.csdn.net/weixin_42740530/article/details/115914113

先要清楚在本地,git会分三个区:工作区、暂存区、本地库。

当使用去做版本移动的时候,那么在使用【--hard】、【--mixed】、【--soft】是不一样的。

1. --soft参数

git reset --soft abcdef
  • 仅仅移动本地库HEAD指针

仅仅是把本地库的指针移动了,而暂存区和你本地的代码是没有做任何改变的。但是这个时候你上次提交到本地库的代码状态是绿色的,即你未做【commit】操作。



2. --mixed参数

git reset --mixed abcdef
  • 移动本地库HEAD指针
  • 重置暂存区

不仅移动了本地库的指针,同时还把暂存区的代码也做了移动。也就是说你上次添加到暂存区的代码,现在变成了红色,即未做【add】操作。如果不写--mixed默认也是此参数



3. --hard参数

git reset --hard abcdef
  • 移动本地库HEAD指针
  • 重置暂存区
  • 重置工作区

不用解释了,除了上面描述的,同时你本地的代码就是你回退的版本代码。

不过很多时候,我们在回退更多的是要保留本地代码的,即使用--mixed参数。除非你是重新拉取一份,那可以使用--hard参数

Git中常见的一些问题总结的更多相关文章

  1. git中常见的几个命令

    git中常见的几个命令 本地仓库 三个区域 工作目录 暂存区 本地仓库 文件的四个状态 未跟踪 untracked 已暂存 staged 已提交commited 已修改 modified 基本命令 g ...

  2. git中常见操作指令

    从git上拉下一个项目: 1.git clone 项目链接                  2. git checkout development (切换到development分支)       ...

  3. 实用:Git 中的一些常见错误

    无论是数据科学家.算法工程师还是普通开发人员,在每个团队协作开发任务中,Git 都是必不可少的版本控制工具,因此掌握它的基本操作十分有必要.但即便是教程满天飞的今天,开发人员在使用 Git 时也还是会 ...

  4. Git 系列(四):在 Git 中进行版本回退

    在这篇文章中,你将学到如何查看项目中的历史版本,如何进行版本回退,以及如何创建 Git 分支以便你可以大胆尝试而不会出现问题. 在你的 Git 项目的历史中,你的位置就像是摇滚专辑中的一个片段,由一个 ...

  5. 如何在Git中撤销一切 | 干货

    翻译:李伟 审校:张帆 译自:Github JF杰微刊:如何在Git中撤销一切 任何一个版本控制系统中,最有用的特性之一莫过于 "撤销(undo)"操作.在Git中,"撤 ...

  6. Unity项目开发过程中常见的问题,你遇到过吗?

    最近看到有朋友问一个unity游戏开发团队,需要掌握哪些知识之类的问题.事实上Unity引擎是一个很灵活的引擎,根据团队开发游戏类型的不同,对人员的要求也有差异,所以不能一概而论.但是,一些在Unit ...

  7. Git的常见基础操作命令

    Git的常见基础操作命令 1安装初始化 1.1安装git本地安装Windows版本 下载地址: https://git-scm.com/downloads/ 1.2初始化Git用户信息配置 配置git ...

  8. Git 基础 —— 常见使用场景

    Git 基础学习系列 Git 基础 -- 安装 配置 别名 对象 Git 基础 -- 常用命令 Git 基础 -- 常见使用场景 Git基础 -- Github 的使用 突然插入 Bugifx 工作, ...

  9. 【转】如何在Git中撤销一切

    翻译:李伟 审校:张帆译自:Github 任何一个版本控制系统中,最有用的特性之一莫过于 “撤销(undo)”操作.在Git中,“撤销”有很多种含义. 当你完成了一次新的提交(commit),Git会 ...

  10. Git 中的回退操作:reset 和 revert

    Git 中回退有 reset 和 revert,这两个的区别就是是否保留更改记录 假设当前的提交情况是:A <- B <- C <- D <- HEAD,如下图: 当前是 D, ...

随机推荐

  1. [Unity]关于Physic Material,物理碰撞

    制作游戏时发现了一些问题,主角身上有刚体(rigbody) 在地面移动时没有什么太大的问题,但是一旦在下落时按住方向键,就会出现角色贴在墙上不下来的问题 通过其他例子发现使用了Physic Mater ...

  2. VMware Workstation Pro 16、docker和Mysql相关

    VMware Workstation Pro 16安装参考 docker容器的使用参考 Docker 容器使用 Docker Hub资源 Docker Hub Mysql数据库安装参考 Mysql数据 ...

  3. vue、iview、VeeValidate 表单验证完整

    1.main.js (1).安装vee-validate npm install vee-validate --save (2).安装vue-i18n npm install vue-i18n --s ...

  4. 正则过滤http|https地址

    let reg = /(\w+):\/\/([^/:]+)(:\d*)?/; let s = http.match(reg); let s1 = http1.match(reg); console.l ...

  5. jreg视频内容整理

    目录 5种变得开心的方法 我(曾经)想死 别再问我过得好不好了 5种变得开心的方法 浪费时间,比如打游戏,什么都不干 停止思考,什么都不要想,刷视频 独处,不要跟别人分享你的痛苦,把自己的痛苦当作世界 ...

  6. python自动化-取消"Chrome正受到自动软件的控制"提示

    chrome浏览器V78及以上版本解决做法,代码如下: from selenium import webdriver chrome_options = webdriver.ChromeOptions( ...

  7. 为win10添加右键“以管理员身份运行MSI”选项

    win+r运行regedit以打开注册表编辑器 定位到HKEY_CLASSES_ROOT\Msi.Package\shell 右键shell,新建 项 项名称为runas 双击runas右边的默认,填 ...

  8. vue3 门户网站搭建6-wangeditor

    门户网站的新闻.公告等文章,内容可配置,故引入 wagneditor 1.安装: npm i wangeditor 2.方便调用,抽成组件: <template> <div ref= ...

  9. Kubernetes二进制安装

    目录: 操作系统初始化配置 部署docker引擎 部署etcd集群 准备签发证书环境 部署Master组件 部署Worker Node组件 部署CNI网络组件 部署flannel 部署Calico 部 ...

  10. ATX server简介及环境搭建

    简介 atx server 是移动设备管理平台: 搭建这样的一个平台,需要  python3.x + nodejs+rethinkdb,及atxserver2和atxserver2-android-p ...