找回密码
 骑士注册

QQ登录

微博登录


已经会用Git了?不会这十招怎么行

2014-7-25 15:24    评论: 11 收藏: 9 分享: 17    

6. 暂存文件的一部分更改以便进行一次提交

通常依据特性来提交是一个好的实践方法,意思是说,每一个提交都只添加一个特性或者修复一个bug。想一下如果你一次修复了两个bug或者添加了两个特性但是都还没有逐个提交该怎么办。这种场景下,你可以将他们一起提交。但是有一个更好的办法:单独暂存这些文件,然后分开提交。

让我们假设你对一个文件做了多个更改,然后想让这些更改分开提交。这时,我们用带-p的添加命令。

git add -p [file_name]

我们来试试这种用法。我添加了3个新行到file_name,但是我只想让第1行和第3行出现在我的提交里。让我们看看git diff的输出是什么样的。

Changes in repo

然后,我们看看带-p选项的add命令会发生什么。

Running add with -p

看起来Git认为所有的更改都是同一个目的的一部分,所以把他们分组到同一个块里。这时,你可以:

  • 输入 y 暂存块
  • 输入 n 不暂存块
  • 输入 e 手动编辑块
  • 输入 d 退出或者跳转到下一个文件
  • 输入 s 分割块

在我们这个例子中,我们想把这个块分割成更小的部分,然后选择其中一些忽略另外一些。

Adding all hunks

如你所见,我们已经逐个添加了第1和第3行,忽略了第2行。你可以看到库的状态并且进行一次提交。

Repository after selectively adding a file

7. 合并多个提交

为了进行核查或者发起一个合并请求(这经常发生在开源项目里),对代码进行了修改提交。但在最后代码被接受之前,你也许会需要修改你的代码。于是你修改代码,但是下一次核查的时候又一次需要进行修改。不知不觉中,你就已经有了好几个提交。理论上你应该用rebase命令把他们合并起来。

git rebase -i HEAD~[number_of_commits]

如果你想合并最后的两次提交,你应该运行下面的命令。

git rebase -i HEAD~2

一旦你运行这个命令,你将进入一个交互式界面,它将询问你想要合并哪些提交。你pick(拣选)最近的提交然后squash(合并)旧的提交。

Git squash interactive

接着你应该提供一个对新提交的说明。这个过程会重写你的提交历史。

Adding a commit message

8. 储藏没有提交的更改

假设你正在修复一个bug或者添加一个特性,突然你被要求展示一下你的工作成果。你现在的工作还没有完成,不够进行一次提交。这时,git stash命令可以用来急救一下。Stash命令跟踪你所有的更改,然后把他们储藏起来以便以后使用。命令如下-

git stash

可以多次储藏更改,查看储藏列表,你可以运行下面的命令:

git stash list

Stash list

如果你想取消储藏,覆盖当前的更改,你可以通过下面的命令使用储藏:

git stash apply

在最后的这个截图里,你可以看到每个储藏都有一个标识符,是一个唯一的数字(尽管在这里我们只有一个储藏)。如果你想使用某个储藏,你在apply命令后面加上这个唯一的标识符:

git stash apply stash@{2}

After un-stashing changes

9. 检查丢失的提交

尽管reflog是一种检查丢失提交的方法,大型的库里却不太实用。这个时候,应该用fsck(文件系统检查)命令。

git fsck --lost-found

Git fsck results

这里你可以看到一个丢失的提交。你可以通过git show [commit_hash] 查看提交的更改或者通过运行git merge [commit_hash]命令进行恢复。

git fsck跟reflog命令相比有一个优点。假设你删除了一个远程分支,然后clone了这个库。用fsck命令你可以找到并且恢复这个删除的远程分支。

10. 最佳选择

之前我已经存记下了那些最优雅的Git命令。但是目前为止,cherry-pick命令是我最喜欢的Git命令,因为它直白的名字和实用的功能!

最简单的情况下,cherry-pick从另一个分支里选出单独的一个提交,然后合并到当前分支。如果你正并行工作在两个或者更多的分支上,你也许会发现一个存在于所有分支上的bug。如果你解决了一个分支上的这个bug,你可以拣选这个对应的提交应用到其他分支上,而不会弄乱其他文件或者提交。

让我们来考虑一个可以使用这个命令的场景。我有两个分支,我想拣选b20fd14: Cleaned junk这个提交到另一个分支上。

Before cherry pick

我切换到想要应用这个拣选出来的提交的分支,然后运行下面的命令:

git cherry-pick [commit_hash]

After cherry pick

尽管这次我们很干净的用了cherry-pick命令,但你应该知道这个命令经常会引起冲突,所以请小心使用。

总结

到了这里,我们结束了这个能使你Git能力提升一个级别的列表。Git是最好的版本控制器,它能完成你能想象到的任何事情。所以,经常试着用Git挑战你自己。一不小心你就会学到很多新东西。


via: http://www.sitepoint.com/10-tips-git-next-level/

译者:love_daisy_love 校对:wxy

本文由 LCTT 原创翻译,Linux中国 荣誉推出

12
查看其它分页:

发表评论


最新评论

我也要发表评论

游客 2014-8-12 14:31 回复
@我的印象笔记
不二怎么做朋友 2014-7-26 01:33  新浪微博网友评论 回复
@我的印象笔记
单弘昊 2014-7-26 00:03  新浪微博网友评论 回复
@我的印象笔记
等魔炮3rd的高町薇薇欧 2014-7-25 22:33  新浪微博网友评论 回复
Mark涨姿势//@Linux中国:自动补全根本不算个事,只是为下面的九个功能铺垫的~//@Nicholas__Xue: 自动补全
Js_初学者 2014-7-25 22:33  新浪微博网友评论 回复
mark
此间的吃货_中二病不治 2014-7-25 22:03  新浪微博网友评论 回复
@我的印象笔记 //@Linux中国: 自动补全根本不算个事,只是为下面的九个功能铺垫的~//@Nicholas__Xue: 自动补全
Linux中国 2014-7-25 22:03  新浪微博网友评论 回复
自动补全根本不算个事,只是为下面的九个功能铺垫的~//@Nicholas__Xue: 自动补全
年年_去旅行 2014-7-25 21:33  新浪微博网友评论 1 回复
马克
[1]
you~ 发表于 2014-7-25 20:01 的评论:
我不会这些也在用。嘿嘿。
linux 2014-7-25 21:27 1 回复
那还差很多呢,我今天一看,晕,原来还有这么多功能——Linus真牛啊。
Nicholas__Xue 2014-7-25 18:03  新浪微博网友评论 回复
自动补全
返回顶部

分享到微信朋友圈

打开微信,点击底部的“发现”,
使用“扫一扫”将网页分享至朋友圈。