编辑推荐: |
本文来自mamicode,主要写给使用命令行来操作Git的用户,用于提高Git使用的效率。 |
|
前言
本文主要写给使用命令行来操作Git的用户,用于提高Git使用的效率。至于使用命令还是GUI(Tortoise
Git或VS的Git插件)就不在此讨论了,大家根据自己的的喜好选择就好。我个人是比较推荐使用命令行的,因为命令行是原生的客户端,当熟悉了命令行以后,使用效率并不会比GUI低。而且我是从GUI(Tortoise
SVN)转命令行的,刚开始的时候也是吐槽命令行的“非人性化”,但我走出了舒适区,真正使用起命令行后,我才发现了自己之前的想法是肤浅的。
指令别名
指令别名就是给一些常用的指令设置一个较短的指令别名来提高Git的使用效率。
如git st(git status):
data:image/s3,"s3://crabby-images/710b0/710b007d5a745e7035b844f86a797b10ce9bab8f" alt=""
使用指令别名,并不会把原指令覆盖掉,而是同时生效:
data:image/s3,"s3://crabby-images/671c3/671c3d79593c7a6224b66e48ceb9b61eac176b3a" alt=""
指令别名输错的时候,也会有提示:
data:image/s3,"s3://crabby-images/5526c/5526c6fed2352b85a22dba9c0e4fce5dbb337e2d" alt=""
我在这里会分享我设置的指令别名,希望能帮助提高使用效率。
1. 查看状态(Show the working tree status) - git status
git st
data:image/s3,"s3://crabby-images/6a0a3/6a0a31be009a5e9dae4e0b6ba751c6bcb3636067" alt=""
2. 提交(Record changes to the repository) - git commit
git ci
data:image/s3,"s3://crabby-images/6d863/6d863c9adb1ce77dc53a5d9495c3d3f1897dc290" alt=""
3. 分支操作(List, create, or delete branches) - git
branch
git br
data:image/s3,"s3://crabby-images/f0e6f/f0e6ffae60c75229a6393942b23bd11357744ced" alt=""
4. 签出(Switch branches or restore working tree files)
- git checkout
git co
签出分支:
data:image/s3,"s3://crabby-images/1b3c4/1b3c4d2696dd1d153465b02fff3e970c4d5246b6" alt=""
签出(还原)工作区文件:
data:image/s3,"s3://crabby-images/32d3c/32d3c2a9a99f0de82917cad5ba72cc91f6c9298f" alt=""
签出(还原)工作区所有文件:
data:image/s3,"s3://crabby-images/4d92e/4d92e4cf8037f9276eecf8e6e38f9a38d29e4413" alt=""
5.差异(Show changes between commits, commit and working
tree, etc) - git diff
工作区(working driectory)与暂存区(staging area)的差异:
git df
单个文件差异:
data:image/s3,"s3://crabby-images/b9a47/b9a474877693c4270a477467c12503c20f0583a9" alt=""
所有文件差异:
data:image/s3,"s3://crabby-images/b37f5/b37f5216178ab3ed8b994ccac15922ea797c9137" alt=""
暂存区(staging area)与本地仓库(repository)的差异:
git dfs
单个文件差异:
data:image/s3,"s3://crabby-images/cf452/cf452d291ad4181df9bbca45e269bb8739e93a25" alt=""
多个文件差异:
data:image/s3,"s3://crabby-images/30e61/30e615592999d4a45571b1d6c3c475be7109bbeb" alt=""
6.合并(Join two or more development histories together)
- git merge
git mr
data:image/s3,"s3://crabby-images/87e91/87e9193bd434c16073e8e162dcadd0e82e9e8bf4" alt=""
7.日志(Show commit logs) - git log
查看最近一条日志:
git last
data:image/s3,"s3://crabby-images/e47ae/e47aec256855c384491a9cebd9c2689e93a1e38d" alt=""
查看日志及分支提交信息:
git ls
data:image/s3,"s3://crabby-images/216e0/216e0c8a8e0f653f5e0ddbff9a6988ceeb3ded47" alt=""
其中绿色的表示local分支,红色的的表示host分支,从上图可以看出,local的master分支、host的master分支、host的dev分支都处于同一个提交,local的dev分支领先于前面提到的3个分支。当版本显示不全提交时,可以按回车(回车)继续加载提交,需要退出是,按字母q。另外,你可以加“-n”指定查看前n条记录:
data:image/s3,"s3://crabby-images/498a6/498a6abf0c7e786ccfd197d4f3df83de427d8f3d" alt=""
查看日志、分支提交信息、提交人、提交时间:
git lg
data:image/s3,"s3://crabby-images/d25ff/d25ffd13f585282fffc5b4f853f7391f7c63976f" alt=""
当版本显示不全提交时,可以按回车(回车)继续加载提交,需要退出是,按字母q。另外,你可以加“-n”指定查看前n条记录:
data:image/s3,"s3://crabby-images/84965/84965300100c77fac52b2c645086fcf32590b7ae" alt=""
8.变基(Reapply commits on top of another base tip)
- git rebase
git rb
data:image/s3,"s3://crabby-images/67169/671698dc0857cf0ca1b5b3c2bd9ea93ed923ec96" alt=""
我理解的rebase和merge功能上比较类似,只是rebase操作后,提交基本都会在一条线上,而merge会从一条线合到到另外一条线。
Merge:
data:image/s3,"s3://crabby-images/59d2a/59d2a8b740513bcc1965b86feed177560a926e4a" alt=""
Rebase:
data:image/s3,"s3://crabby-images/097bc/097bc3bf78fa5c9d52657fb601a1025d3a7463fa" alt=""
9.拣选(Apply the changes introduced by some existing
commits) - git cherry-pick
git cb
data:image/s3,"s3://crabby-images/8ed81/8ed81c9dd70ea16969bae40b06237275bae76210" alt=""
从图中看看出,cherry-pick是把某个提交复制过来作为一个新的提交,和merge或者rebase的效果不同,check
pick后可以进行merge或rebase操作:
data:image/s3,"s3://crabby-images/ffe50/ffe50c5d13548279fa0483ce89fd12b368e905f1" alt=""
使用Beyond Compare作为差异比较工具
命令行自带的文件差异比较工具功能比较简单,用来查看或对比文件差异时,可能效果不太好,特别是在解决冲突的时候,但是我们可以集成一些比较强大的差异比较工具,比如本文提到的Beyond
Compare。那么,我们先看一下例子:
自带的差异比较效果:
data:image/s3,"s3://crabby-images/f9cdb/f9cdb550ebea24818f13f441f9231586f186a88c" alt=""
使用difftool指令调用Beyond Compare的比较效果:
data:image/s3,"s3://crabby-images/ebe03/ebe033f175ec1c074c6c070f2b59e056e318178c" alt=""
data:image/s3,"s3://crabby-images/a1ae9/a1ae92a1ab5c1b767250cb7d128daa165d1a890d" alt=""
当然difftool也可以使用指令别名:
data:image/s3,"s3://crabby-images/84d3c/84d3c72c670693c0eee3f068518b6f707af480a5" alt=""
解决合并冲突:
我们在dev的a.txt文件中添加“dev”内容,在master分支上添加“master”内容,然后用master分支合并dev。
data:image/s3,"s3://crabby-images/183a3/183a3744dea2d3b7a7c6f2d5d4ec2e13abb0421e" alt=""
使用mergetool指令调用Beyond Compare合并冲突:
data:image/s3,"s3://crabby-images/335ed/335ed2d2438806ccb3fc4cd2304454500f126bca" alt=""
data:image/s3,"s3://crabby-images/28973/28973c03d9c5f105d3d6a34262533ef94e33058e" alt=""
由上图可以看出,左边是当前分支的版本,右边的是需要合并的分支的版本,中间的是相同部分的版本,处理冲突的策略大概有以下几种:
#1 当前分支版本替换合并分支版本,点击绿色的箭头。
#2 合并分支版本替换当前分支版本,点击粉色的箭头。
#3 同时需要两个版本的内容,点击绿色或粉色的箭头,然后把另外的分支的内容拷贝到下方的文本编辑框。
#4 只要相同部分的内容,什么都不干。
#5 其他。
最后,点击红色的感叹号,表示已解决冲突。我这里选择#3的策略:
data:image/s3,"s3://crabby-images/5fb70/5fb70f784f9f78e3ea42cc66d737fa2c07563742" alt=""
关闭Beyond Compare,完成合并操作。
data:image/s3,"s3://crabby-images/0ba1d/0ba1d7d391c175af17ebb90590cc5dbc544cda65" alt=""
如何配置
.gitconfig是配置的主要文件,它一般在C:\Users\{用户名}目录中,如果没有,可以通过以下两步创建:
#1 打开命令行工具
data:image/s3,"s3://crabby-images/a4fb2/a4fb25782ee03da7dafd1711a54e776c8e049e2b" alt=""
#2 执行设置用户名或者设置邮箱的指令。
设置用户名:
git config --global user.name "{your username}"
设置邮箱:
git config --global user.email "{your email}"
打开.gitconfig文件,把以下内容拷贝到文件中,完成指令别名的配置:
[alias]
st = status
ci = commit
co = checkout
br = branch
df = diff
dft = difftool
dfs = diff --staged
dfts = difftool --staged
mr = merge
mrt = mergetool
last = log -1 HEAD
ls = log --oneline --graph --all
--decorate
g = log --oneline --graph --all --decorate
--pretty= format :"%h%x20% Cgreen%d% x20% Cred%
an%x20% C(yellow)% ad%x20% Creset%s" --full-history
--date = short
rb = rebase -i
cp = cherry-pick
打开.gitconfig文件,把以下内容拷贝到文件中,完成Beyond Compare的配置:
[diff]
tool = bc4
[difftool]
prompt = true
[difftool "bc4"]
cmd = \"D: /Program Files /Beyond
Compare 4 /bcomp.exe\" "$ (cygpath -w $LOCAL)"
"$ REMOTE "
[merge]
tool = bc4
[mergetool]
prompt = true
[mergetool "bc4"]
#trustExitCode = true
cmd = \"D:/Program Files /Beyond
Compare 4 /bcomp.exe \" "$LOCAL" "$REMOTE"
"$BASE" "$ MERGED "
最终效果如图所示:
data:image/s3,"s3://crabby-images/0bec3/0bec388b559c46ad0dddfb139325320c9a36e750" alt=""
最后
希望以上分享的小技巧可以提高大家的效率,大家也可以根据自己的需要去设置指令别名,欢迎大家讨论及分享指令别名的使用心得。 |