关于 Git 的一些使用技巧

~/.gitconfig 文件

在第一次使用Git来提交代码到仓库时,你可能需要进行一些基础配置,如下:

  git config --global user.email "you@email.com"
  git config --global user.name "Your Name"

你可能没有意识到,上面的命令其实是在修改/.gitconfig文件中的内容,/.gitconfig存储的是git的全局配置,可以对 Git 配置进行很多操作。包括git命令别名的命名,打开或关闭特定的选项,git diff使用何种算法或者git merge默认使用什么策略。

如下面就是我定义的git log的一些别名。

 [alias]
      lg = !"git lg1"
      lg1 = !"git lg1-specific --all"
      lg2 = !"git lg2-specific --all"
      lg3 = !"git lg3-specific --all"

仓库中的.gitconfig文件

在上面配置命令中,参数 --global 告诉git更新全局的配置文件,也即是~/.gitconfig文件,如果省略--global参数,git将更新指定仓库的配置,该配置文件存在.git/config中。

.git/config文件中的设置将覆盖~/.gitconfig文件中的配置。所以,如果你需要为指定的仓库使用不同的用户地址。只需要省略--global即可,在仓库下运行git config user.email "your@example.com"即可,如下面我执行命令后config文件多出了[user]选择。

[user]
   email = test@zhoushuai.com

几乎任何可以在~/.gitconfig中的配置,你也可以在.git/config中设置,从而在指定的仓库中使用。

定义别名

别名的设置可以在~/.gitconfig文件中配置,就像shell的别名一样给一个命令换个名字。如执行
git config --global --add alias.lg log,运行git lg将和git log相同,其实在定义别名的时候直接修改~/.gitconfig文件来得更直接。

可视化提交视图

如果你在一个有很多分支活动的项目上工作,有时很难掌握正在发生的所有工作以及他们是如何工作的。当然也有各种GUI工具,如source tree等,如果你是一个命令行爱好者或者认为切换工具分散注意力,那么用 git 命令行来获取提交视图是很好的。这时候git log 命令的 --graph就发挥作用了。

以下是可视化仓库的提交视图命令。

git log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit --date=relativ

git add -p

使用git的最好做法是确保每次提交只包含一个逻辑修改,无论是修复错误还是新增功能。但是有时候,还是会进行多次提交。怎么设法把它分开,以便每次提交只包含适当的改变。git add --path派上用场了。

添加这个参数后,执行 git add 命令将会查看工作区副本中的所有更改,并且对于每一个更改都将提示你是否将其分阶段提交,跳过它或者延迟操作。官方介绍的就是交互式的操作。git add -p 是生成结构良好的提交的最佳工具。

假设你对单个文件进行了多次更改,并希望他们出现在单独的提交中。在这种情况下加上 -p 参数。

git add -p [filename]

git blame

blame这个单词就十分的形象生动,找出是谁的责任,这个命令便于我们找出问题,此命令会显示文件中每一行的作者。

git blame <filename>

执行 git blame config.toml ,显示如下:

^9ffbfd8 (xiaozhang        2018-10-06 18:19:13 +0800 10)
^9ffbfd8 (xiaozhang        2018-10-06 18:19:13 +0800 11) [params]
a558046f (xiaozhang 2019-03-02 00:40:04 +0800 12) subtitle = "Go语言、Golang、IT互联网、文学、艺术"
^9ffbfd8 (xiaozhang        2018-10-06 18:19:13 +0800 13) keywords = "Go语言,Golang"
7bb650fa (xiaozhang        2018-10-06 21:50:12 +0800 14) busuanzi = true
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Git使用教程:https://blog.csdn.net/tgbus18990140382/article/de...
    SkTj阅读 7,775评论 1 11
  • Git常用语法 [TOC] Git简介 描述 ​ Git(读音为/gɪt/。)是一个开源的分布式版本控制系统,...
    君惜丶阅读 9,043评论 0 13
  • 关注公众号:“程序员成长软技能” ,日拱一卒,功不唐捐!13个Git小技巧,让你拥有更有用更强大的代码版本控制经...
    数大招疯阅读 3,203评论 0 0
  • git作为时下最流行的代码管理工具,Git权威指南总结了十条喜欢Git的理由: 异地协同工作; 现场版本控制; 重...
    古斟布衣阅读 5,795评论 0 12
  • 6月4日复盘 早起 6:02完成✅ 每日三目标 1.60s练习 ✅ 2.读《人生效率手册》✅ 3. 专业知识 ✅ ...
    爱尚_c631阅读 1,170评论 0 0