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

前言

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

指令别名

  指令别名就是给一些常用的指令设置一个较短的指令别名来提高Git的使用效率。

  如git st(git status):

  

  

  使用指令别名,并不会把原指令覆盖掉,而是同时生效:

  

  指令别名输错的时候,也会有提示:

  

  我在这里会分享我设置的指令别名,希望能帮助提高使用效率。

  1. 查看状态(Show the working tree status) - git status

git st

  

  2. 提交(Record changes to the repository) - git commit

git ci

  

  3. 分支操作(List, create, or delete branches) - git branch

git br

  

  4. 签出(Switch branches or restore working tree files) - git checkout

git co

  签出分支:

  

   签出(还原)工作区文件:

  

  签出(还原)工作区所有文件:

  

  5.差异(Show changes between commits, commit and working tree, etc) - git diff

  工作区(working driectory)与暂存区(staging area)的差异:

git df

  单个文件差异:

  

  所有文件差异:

  

  暂存区(staging area)与本地仓库(repository)的差异:

git dfs

  单个文件差异:

  

  多个文件差异:

  

  6.合并(Join two or more development histories together) - git merge

git mr

  

  7.日志(Show commit logs) - git log

  查看最近一条日志:

git last

  

  

  查看日志及分支提交信息:

git ls

  

  其中绿色的表示local分支,红色的的表示host分支,从上图可以看出,local的master分支、host的master分支、host的dev分支都处于同一个提交,local的dev分支领先于前面提到的3个分支。当版本显示不全提交时,可以按回车(回车)继续加载提交,需要退出是,按字母q。另外,你可以加“-n”指定查看前n条记录:

  

  查看日志、分支提交信息、提交人、提交时间:

git lg

  

  当版本显示不全提交时,可以按回车(回车)继续加载提交,需要退出是,按字母q。另外,你可以加“-n”指定查看前n条记录:

  

  8.变基(Reapply commits on top of another base tip) - git rebase

git rb

  

  我理解的rebase和merge功能上比较类似,只是rebase操作后,提交基本都会在一条线上,而merge会从一条线合到到另外一条线。

  Merge:

  

  

  Rebase:

  

  9.拣选(Apply the changes introduced by some existing commits) - git cherry-pick 

git cb

  

  

  从图中看看出,cherry-pick是把某个提交复制过来作为一个新的提交,和merge或者rebase的效果不同,check pick后可以进行merge或rebase操作:

  

使用Beyond Compare作为差异比较工具

  命令行自带的文件差异比较工具功能比较简单,用来查看或对比文件差异时,可能效果不太好,特别是在解决冲突的时候,但是我们可以集成一些比较强大的差异比较工具,比如本文提到的Beyond Compare。那么,我们先看一下例子:

  自带的差异比较效果:

  

  使用difftool指令调用Beyond Compare的比较效果:

  

  

  

  当然difftool也可以使用指令别名:

  

  

  解决合并冲突:

  我们在dev的a.txt文件中添加“dev”内容,在master分支上添加“master”内容,然后用master分支合并dev。

  

  

  使用mergetool指令调用Beyond Compare合并冲突:

  

  

  由上图可以看出,左边是当前分支的版本,右边的是需要合并的分支的版本,中间的是相同部分的版本,处理冲突的策略大概有以下几种:

  #1 当前分支版本替换合并分支版本,点击绿色的箭头。

  #2 合并分支版本替换当前分支版本,点击粉色的箭头。

  #3 同时需要两个版本的内容,点击绿色或粉色的箭头,然后把另外的分支的内容拷贝到下方的文本编辑框。

  #4 只要相同部分的内容,什么都不干。

  #5 其他。

  

  最后,点击红色的感叹号,表示已解决冲突。我这里选择#3的策略:

  

  

  关闭Beyond Compare,完成合并操作。

  

如何配置

  .gitconfig是配置的主要文件,它一般在C:\Users\{用户名}目录中,如果没有,可以通过以下两步创建:

  #1 打开命令行工具

  

  

  #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
  lg = 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"

  最终效果如图所示:

  

最后

  希望以上分享的小技巧可以提高大家的效率,大家也可以根据自己的需要去设置指令别名,欢迎大家讨论及分享指令别名的使用心得。

时间: 2024-12-25 19:44:56

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

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小技巧--如何从其他分支merge个别文件或文件夹

在实际工作中,一个大型的项目或版本迭代可能不是一次上线,可能会分好几次上线,这时候就会涉及创建多个分支,进行分别开发. 创建分支 功能分为2个分支,分别为A.B. A上面有个列表页功能 B上面有个详情页功能,还有个系统消息功能 产品经理说先上列表功能,于是我们就开发A分支,列表功能很快开发完成. 第二天按常理开发B分支,开发到一半,产品经理说目前的系统消息功能需要急着上线,要和列表功能一起上线,当时就懵逼了,然后赶紧放下详情页的开发,立马去开发系统消息功能,开发完之后需要将列表功能和系统消息功能

Git小技巧:VIM中如何填写注释信息

使用Git命令行工具的时候,经常一不小心就进入VIM界面,例如git commit没有填写任何描述信息.对于习惯了Windows可视化操作界面的用户,可能一下子会觉得无所适从,只能在键盘上一顿短按.下面简单介绍一下进入VIM界面后的操作: 1. 退出窗口 进入到VIM后,键盘没有哦按照你的预期出现结果,这是你最希望的操作就是退出,可以参考下面的操作方式: 1)按键Esc,如果无效,连续按两次 2)当底部提示行出现空白时,输入冒号":" 3)再输入字母"q",回车 (

git小技巧

在输入git命令的时候,可以按两下tab键,就会看到候选的命令了. 比如说: git co<tab><tab> commit  config 这时候,在输入m<tab> 就自动选择并补全为git commit命令. 在输入命令之后,忘记相关选项的名字,可以输入开头的几个字母,然后按tab键. 比如说: git log --s<tab> --shortstat    --since=    --src-prefix=    --stat    --summar

8 个 Git 的小技巧

git 已经成为了我日常必备工具之一,我总结我几乎每天使用的8个有用(且简洁)的git技巧. 使用-p选择性添加 当你想提交内容时,你可以通过使用 git commit -am 来选择所有文件或使用 git add file 来添加特定文件.然而,有时候你可能想只添加文件的一部分来提交.你可以用 git add -p 交互性地选择哪些你想提交的部分. 在选择完你所想要提交的区块后,只需要做一个 git commit(没有 -a),这样只会提交选中的部分.同样可以使用 git checkout -

Angular(03)-- lint风格规范和WebStorm小技巧

在开始讲 Angular 各个核心知识点之前,想先来讲讲开发工具 WebStorm 的一些配置以及相应配置文件如 tslint.json 的配置. 因为我个人比较注重代码规范.代码风格,而对于这些规范,我只有一个观点:一切需要依赖开发人员的主观意识去遵守的规范都没有多大意义. 以前做 Android 开发时会借助 AndroidStudio 来强制遵守一些规范,现在前端项目我用的是 WebStorm 开发,这两个开发工具本质上同源,所以很多功能都差不多. 那么,这篇就来讲一讲,如何对 WebSt

自媒体运营的小技巧有哪些?整理分享4种方法!

从事自媒体运营行业想要获得可观的收益那么就一定要一定的运营技巧.现在自媒体行业竞争这么激烈想要从中脱颖而出是非常困难的,那么应该如何做自媒体运营才能获得可观的效果呢? 现在自媒体运营的局面基本上处于一个"二八定律"当中,被公众所熟知的运营者往往只有那么一少部分,那么我们要做的是从那"八"当中脱颖而出二不是去战胜那当中的"2".今天易撰自媒体工具的小编就跟大家分享一些运营当中的实用小技巧希望能够提高大家的运营效率. 1.找到突破口 现在自媒体平台的

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

25个 Git 进阶技巧

我已经使用git差不多18个月了,觉得自己对它应该已经非常了解.然后来自GitHub的Scott Chacon过来给LVS做培训,而我在第一天里就学到了很多. 作为一个对git感觉良好的人,我觉得分享从社区里掌握的一些有价值的信息,也许能帮某人解决问题而不用做太深入研究. 基本技巧 1. 安装后的第一步 在安装好git后,你第一件该做的事是设置你的名字和电子邮箱,因为每次提交都要用到这些信息: $ git config --global user.name "Some One" $ g