大家好,今天我们来介绍git当中一项非常重要的功能——交互式工具

有的时候如果我们要处理的文件很多,使用git add .等操作会非常有隐患,因为很有可能我们一不小心就疏忽了一些内容。如果我们使用一个文件名一个文件名地填写呢,又非常地复杂,体验并不好。所以呢git当中还提供了第三种方法,也就是今天要介绍的内容——交互式工具。

交互式暂存

交互式暂存的命令非常简单,其实就是一个参数,-i。这里的i表示的是interactive,也就是交互的意思。当我们执行这个命令之后,git会进入一个交互式的终端。这样我们就可以通过一些简短地命令和git进行交互。

首先,我们输入git add -i 进入交互式的命令。

可以看到这里有8个选项,这里的选项大家应该都能看懂,其中集成了很多种功能,我们接下来一个一个讲解。

首先是将新文件添加到暂存区,我们选择4,表示添加未被git管理的文件,接着又会询问我们要添加的文件。这里我们就不用再输入文件名了,直接选择序号即可。我们先添加一个,选择3。之后我们会看到3对应的文件名前面被打上了*,表示这个文件将会被添加。

接着我们再敲一次回车,可以回到上级菜单,然后我们选择7退出,可以看到git的状态已经改变了。

查看改动

我们将改动添加到暂存区之后,我们还可以使用git add -i 来查看某一个文件的具体改动。操作方法也非常简单,我们同样通过git add -i 进入交互模式,然后选择6进入diff模式。

接着我们输入1,表示我们要查看的改动,git会打开一个vim窗口,为我们展示这个文件当中被我们添加的改动。

它的效果等价于我们执行git diff --cached

取消暂存

如果我们add了之后,发现add错了,想要反悔,那么也是容易的,我们可以使用revert功能撤销我们这次的add

操作也很简单,我们还是输入git add -i 进入交互式的命令。会发现我们刚进来的时候就提示我们当前暂存区的状态。这里我们选择3进行撤销,git会展示出我们暂存区的所有文件,这里我们只提交了一个文件,所以也只能看到一个。


image-20201022084056498

这里我们选择1号文件,然后退出,会发现我们回到了git提交之前的状态。

暂存补丁

最后介绍一下补丁的功能,这个功能我用的不多,不过用好了可以在一些情况下大大简化我们的操作。

当我们执行暂存操作的时候,我们针对的主体都是某一个文件。但是会有这样一种情况,某一个文件当中的改动很多,我们只想要把其中的一部分添加进git,另外一部分先保留在本地。这种情况也很常见,比如同时开发两个功能,一个开发好了,另外一个还在测试。为了赶工期,决定先把其中的一个功能先上线,那么还在测试的功能显然不能被提交,否则可能会带来隐患。

针对这种情况,我们就需要使用补丁。为了演示,我们在之前的文件当中加了两行废话,然后执行git add -i,选择5.

当我们选择了我们想要进行补丁的文件并且按回车之后,git会把我们的改动一个部分一个部分地询问我们。

这里的命令可能看不明白,没关系,我们输入?可以获取完整的含义。

说了这么多,其实关键的只有两个,y表示需要把它加入存储,n表示不加入。这样当我们操作完了之后,我们再来查看状态,会发现刚才我们操作过的文件当中,一部分被添加了进来,另外一部分没有。

总结

怎么样,交互式命令是不是非常好用呢?

它的最大的一个优点就是将多个命令集合在了一起,可以一个命令实现多个功能。并且每个功能都以交互的形式展现,可以方便我们的操作,降低我们搞错的几率。这也是很多git大神非常喜欢的功能,希望大家都能学会。

今天的文章就到这里,衷心祝愿大家每天都有所收获。如果还喜欢今天的内容的话,请来一个三连支持吧~(点赞、关注、转发

原文链接,求个关注

{{uploading-image-87920.png(uploading...)}}

学会了这一招,距离Git大神不远了!的更多相关文章

  1. 想成为Git大神?从学会reset开始吧

    大家好,今天我们来着重介绍一个非常关键的功能就是reset.在上一篇文章介绍修改历史记录的时候曾经提到过,当我们需要拆分一个历史提交记录的时候需要使用reset.估计很多小伙伴不明白,reset究竟做 ...

  2. 详解git rebase,让你走上git大神之路

    在之前的文章当中我们介绍了git merge的用法,明白了通过git merge我们可以合并两个分支的改动.这样我们就可以很方便地进行协同开发了,每个人都在自己的分支下开发代码,开发完毕之后再一起合并 ...

  3. 多年的.NET开发,也只学会了这么几招

    折腾了这么多年的.NET开发,也只学会了这么几招 软件开发不是生活的全部,但是好的生活全靠它了   随着工作年龄逐渐增加,身边的重担也越来越多.以前可以在公司加班到晚上10点,现在不行了.以前可以通宵 ...

  4. 文章如何做伪原创 SEO大神教你几招做"原创"网站文章的心得

    想要创作出好的文章并被百度所喜欢,就非常需要SEO的优化能力,以及要对文章进行塬创或伪塬创,那么,如何做伪塬创文章?以及如何做好塬创网站文章呢?对此,本文小编就为大家带来了几招做"塬创&qu ...

  5. 【推荐】Java工程师如何从普通成为大神值得一读

    本文源自 http://www.hollischuang.com/archives/489 一点感悟 java作为一门编程语言,在各类编程语言中作为弄潮儿始终排在前三的位置,这充分肯定了java语言的 ...

  6. 李洪强iOS开发之大神必备的Xcode插件

    iOS开发大神必备的Xcode插件 写在前面 工欲善其事,必先利其器,iOS开发中不仅要学会Xcode的基本操作,而且还得学会一些Xcode的使用技巧,如掌握常用的快捷键等,还有就是今天要说到的Xco ...

  7. 从菜鸟到大神:Java高并发核心编程(连载视频)

    任何事情是有套路的,学习是如此, Java的学习,更是如此. 本文,为大家揭示 Java学习的套路 背景 Java高并发.分布式的中间件非常多,网上也有很多组件的源码视频.原理视频,汗牛塞屋了. 作为 ...

  8. iOS组件化思路-大神博客研读和思考

    一.大神博客研读 随着应用需求逐步迭代,应用的代码体积将会越来越大,为了更好的管理应用工程,我们开始借助CocoaPods版本管理工具对原有应用工程进行拆分.但是仅仅完成代码拆分还不足以解决业务之间的 ...

  9. 大神的vim配置

    大神的vim配置,O(∩_∩)O spf13-vim : Steve Francia's Vim Distribution __ _ _____ _ ___ _ __ / _/ |___ / __ _ ...

随机推荐

  1. 嵌入式linux和stm32嵌入式开发这两者之间有什么关联性

    对于更开始入坑的同学,可能也像我一样搞不清楚两者的区别与联系.现在结合知乎网上的相关资料发一篇文章来具体分析. 基于STM32的开发属于微控制器开发领域,主要开发工具是keil或IAR,这种开发更准确 ...

  2. win10右键打开PowerShell

    win10右键打开PowerShell 转载自:http://www.xitongzhijia.net/xtjc/20170526/98756.html 如图: 1.首先在桌面新建一个txt文文件 复 ...

  3. Redis中的一致性哈希问题

    在说redis中的哈希(准确来说是一致性哈希)问题之前,先来看一个问题:为什么在分布式集群中一致性哈希会得到大量应用? 在一个分布式系统中,要将数据存储到具体某个节点,或者将来自客户端的请求分配到某个 ...

  4. first day for my bolg

    做为一名毕业不久的兢兢业业的前端小白,傻到一直用word做笔记,还有各种手抄(捂脸),下定决心以后改用博客,据说大神们都是这么做的!嘿嘿,先把各种笔记腾上来,内容实在惨不忍睹各种智商感人,希望不要有人 ...

  5. redis 在windows 下的安装和使用

    1.下载试用 首先下载https://github.com/dmajkic/redis/downloads,我下载的是2.4.5的版本,是个压缩包解压后里面有两个文件夹一个是32bit一个是64位的, ...

  6. jquery播放图片

    * { margin:0; padding:0; word-break:break-all; } body { background:#FFF; color:#333; font:12px/1.5em ...

  7. 《.NET 5.0 背锅案》第3集-剧情反转:EnyimMemcachedCore 无罪,.NET 5.0 继续背锅

    今天晚上基于第2集中改进版的 EnyimMemcachedCore 进行了发布,发布过程中故障重现,最大的嫌犯 EnyimMemcachedCore 被证明无罪,暂时委屈 .NET 5.0 继续背锅. ...

  8. kafak ack应答机制

    ack 应答机制 对于某些不太重要的数据,对数据的可靠性要求不是很高,能够容忍数据的少量丢失, 所以没必要等 ISR 中的 follower 全部接收成功. 所以 Kafka 为用户提供了三种可靠性级 ...

  9. ceph在centos7下一个不容易发现的改变

    在centos6以及以前的osd版本,在启动osd的时候,回去根据ceph.conf的配置文件进行挂载osd,然后进行进程的启动,这个格式是这样的 [osd.0] host = hostname de ...

  10. Elasticsearch 第八篇:数据类型 Array、Nested、Object 的设计与应用

    h2.post_title { background-color: rgba(43, 102, 149, 1); color: rgba(255, 255, 255, 1); font-size: 1 ...