8 个 Git 的小技巧

git 已经成为了我日常必备工具之一,我总结我几乎每天使用的8个有用(且简洁)的git技巧

使用-p选择性添加

当你想提交内容时,你可以通过使用 git commit -am 来选择所有文件或使用 git add file 来添加特定文件。然而,有时候你可能想只添加文件的一部分来提交。你可以用 git add -p 交互性地选择哪些你想提交的部分。

在选择完你所想要提交的区块后,只需要做一个 git commit(没有 -a),这样只会提交选中的部分。同样可以使用 git checkout -p 来选择需要恢复的部分。添加后,你可以使用 git diff –cached 来查看差异。

交互式的重建基准(Interactive Rebase)

如果你在一个分支上工作,同时进行了一些 WIP 提交(commit) ,以用来压缩合并(squash)或者删除一个提交(commit)以及这个提交的恢复, 你可以做一个交互式的重建基准(rebase),用来重新组织提交。

为了做到这点,你需要运行命令 git rebase -i ,这里的是你想要重写之前的一个提交(commit)的sha1值。接下来,它将在你的编辑器(在$EDITOR环境变量,或者git配置里面指定的编辑器)上面打开一些指令,用来变更提交(commit)历史,你可以选择压缩合并(将两次提交合并为一次新的提交),重写(变更提交信息),编辑甚至删除一个提交(commit)。

请注意这改变了历史信息,因此,如果你提交了这个变更,你将不得不再一次强制提交(push),所以,绝不要在主分支,或者有其他人(除你之外)在使用的分支上面做这个操作。

储藏(Stashing)

如果你正忙于什么事情,你必须更改文本去修复其他问题,去git stash查到到储藏在当前中的更改。然而,过一段时间后,你可能就会忘记关于这个已储藏的变更。因此,我试着去保持一个储藏0(就像收件箱0如果没有储藏的情况)规则。每一次我储藏一个美元信号出现在我的输出,并且我通过git stash show -p检查,还可以通过git stash pop弹出或者通过git stash clear丢弃。

全局gitignore

在项目的根目录,你可以通过文件.gitignore来指定git需要忽略的文件。但是,如果存在git需要忽略的文件,同时,你又是唯一创建这个文件的人(如vim的 bkp文件,编辑器或者操作系统生成的一些文件,如OSX生成的.DS_Store文件),你可以在配置文件中指定全局的gitignore文件,它和工程中的.gitignore文件使用一样的语法格式。

git config --global core.excludesfile=/Users/flores/.gitignore

空格警告

我不得不承认:有时候我忘记代码尾部的一些空格。但是,通常我不会提交它们,因为我使用了这个选项:apply.whitespace=warn。每次我通过git add -p增加文件中的一大块代码,同时,这个代码块尾部包含空格,由于git给出警告提示,因此我可以在提交前修正它们。

自动重建代码基准(Auto setup rebase)

另一个很酷的技巧是自动重建代码基准(auto setup rebase)。如果你有一个分支,并做了一些commit但并未push。同时,其他人也在这个分支上进行了commit和push。当你pull的时候,git会创建一个commit来合并你的commit到上游(upstream)commit。由于这个commit毫无意义,我更倾向于,在pull时,通过配置来自动重建代码基准(auto setup rebase):branch.autosetuprebase=always。设置之后,每个pull操作,git都会尝试在当前版本的上游(upsteam)分支重新使用你的commit。

更好的日志(logging)

你是否尝试过在一个分支中找一个特定的提交啊? git log 给我们提供了一些基本的信息,不过你使用下面的命令会得到更多有用的信息:

git log --graph --decorate --pretty=oneline --abbrev-commit

–graph 会在各个提交之间打印出线条,这些线条可以展示出分支之间的关系。

–decorate 显示出分支处在哪一次提交上。

–pretty=oneline 只是在一行中显示 sha1 和 提交的注释(译者将title一词应对到更精确的注释)

–abbrev-commit 用开始的7个sha1字符代替整个sha1(他在你的仓库中是唯一的)。

你可以到explain shell去看这些选项的更详细(且是完整)的解释。

改写提交的注释

如果你在提交代码的时候注释不能准确的描述当前提交,或者你写了错别字。你可以使用 git commit –amend 来改写你已经提交的注释。 他允许你在命令行中通过 -m 选项来指定新注释或直接打开系统默认编辑器让你来编辑新的注释。  另外你还可以把一些新的变化加入到上一次提交中。请记住 该操作和 Interactive Rebase 一样,他会改变提交历史。如果你已经把你改动的这次提交push了,那么你需要强制(force)push这次变化。

欢迎你在评论中分享你在工作中发现一些能提升工作效率的 git小技巧。

本文转自:码农网

时间: 2024-10-25 06:26:02

8 个 Git 的小技巧的相关文章

git使用小技巧

(1)一次添加多个文件的简单处理办法 依次z所有的文件,只需要一次commit提交文件即可: (2) git status命令可以让我们时刻掌握仓库当前的状态; (3)修改文件相关操作: git status命令可以让我们时刻掌握仓库当前的状态; git diff查看修改的是什么,以及修改前的文件,放心一些 git add readme.txt提交修改文件 运行git status看看当前仓库的状态 git commit -m "add distributed"提交修改 再用git s

git使用小技巧汇总

批量添加(add)命令: git add -a #将所有文件改动提交到暂存区 git add . #将新建和修改的文件改动提交到暂存区 git add -u #将修改和删除的文件改动提交到暂存区 添加忽略的文件,执行add操作是不提交,有三种方法: 1.在仓库目录下新建一个.gitignore文件,这个文件对其所在目录及其子目录均有效.将这个文件提交后,其他人也可以用这一套忽略的规则. 2.先创建一个txt文本文件,比如ignore.txt,然后执行下面命令: git config --glob

Git使用小技巧之回滚和撤销

想要获取更多文章可以访问我的博客?-?代码无止境. 日常的开发,我们难免会创建错误的git提交记录,整个时候git给我们提供了两个命令来解决这个问题.一个命令是git reset,另一个是git revert.两者有啥区别呢?两者主要的区别是,git reset命令是回滚某次提交,被回滚的提交将不会出现在提交记录中,而git revert命令是创建一个新的提交来达到撤销的目的,被撤销的提交和撤销的提交都会出现在提交记录中. 准备 首先呢,我们还是需要准备一个git仓库,并且准备一个可以修改的文件

git小技巧:git blame && git show 查看某一行代码的修改历史

先查看某行代码由谁写的,在哪个commit中提交的: git blame file_name git blame -L 58,100 KeyboardActivity.java 其显示格式为: commit ID | 代码提交作者 | 提交时间 | 代码位于文件中的行数 | 实际代码 类似于下面这样: 这样,我们就可以知道commit ID了,然后使用命令:Git show commitID来看~ git小技巧:git blame && git show 查看某一行代码的修改历史

Git小技巧 - 指令别名及使用Beyond Compare作为差异比较工具

前言 本文主要写给使用命令行来操作Git的用户,用于提高Git使用的效率.至于使用命令还是GUI(Tortoise Git或VS的Git插件)就不在此讨论了,大家根据自己的的喜好选择就好.我个人是比较推荐使用命令行的,因为命令行是原生的客户端,当熟悉了命令行以后,使用效率并不会比GUI低.而且我是从GUI(Tortoise SVN)转命令行的,刚开始的时候也是吐槽命令行的“非人性化”,但我走出了舒适区,真正使用起命令行后,我才发现了自己之前的想法是肤浅的. 指令别名 指令别名就是给一些常用的指令

git的几个小技巧

git的几个小技巧 分享git的几个小技巧,后面会根据使用补充.目前包括git撤销本地修改.git回退到前n个版本.git多用户提交冲突解决.git 命令简化.欢迎大家补充^_* 1.git撤销本地修改 Java 1 2 git reset --hard origin/master git pull 2.git回退到前n个版本 如下为向前回退3个版本,git reset –hard HEAD~3 3.git多用户提交冲突一 场景:用户UserA修改了文件File1,用户UserB也修改了文件Fi

最强 Android Studio 使用小技巧和快捷键【非原创】

(发现本文是个很不错的文章,相当实用,特分享与大家.分享自:http://m.open-open.com/m/lib/view/1458715872710.html 特此声明,好记性不如烂笔头,market下来以备后用) 原文如下: 写在前面 本文翻译自 Android Studio Tips by Philippe Breault,一共收集了62个 Android Studio 使用小技巧和快捷键. 根据这些小技巧的使用场景,本文将这62个小技巧分为常用技巧(1 – 28).编码技巧(29 –

【转载】PHP 开发者该知道的 5 个 Composer 小技巧

Composer是新一代的PHP依赖管理工具.其介绍和基本用法可以看这篇<Composer PHP依赖管理的新时代>.本文介绍使用Composer的五个小技巧,希望能给你的PHP开发带来方便. 1. 仅更新单个库 只想更新某个特定的库,不想更新它的所有依赖,很简单: 1 composer update foo/bar 此外,这个技巧还可以用来解决“警告信息问题”.你一定见过这样的警告信息: 1 Warning: The lock file is not up to date with the

Android Studio 使用小技巧和快捷键

Alt+回车 导入包,自动修正 Ctrl+N   查找类 Ctrl+Shift+N 查找文件 Ctrl+Alt+L  格式化代码 Ctrl+Alt+O 优化导入的类和包 Alt+Insert 生成代码(如get,set方法,构造函数等) Ctrl+E或者Alt+Shift+C  最近更改的代码 Ctrl+R 替换文本 Ctrl+F 查找文本 Ctrl+Shift+Space 自动补全代码 Ctrl+空格 代码提示 Ctrl+Alt+Space 类名或接口名提示 Ctrl+P 方法参数提示 Ctr