深入学习Git之Git命令汇总

前言: Git在团队项目开发中是常用的,但平时只用到少部分命令,那些命令足够应对日常工作,导致一直没有抽时间深入学习一下Git,刚好过年有空有闲, 把之前存的 Scott Chacoon and Ben Straub大神的《Pro Git》(V2.1.57 2021/10/16)这本书看一下,顺便做下学习记录

第一部分先整理下Git命令,方便查阅

一、Git命令

1、设置与配置

- git config : Git做很多工作都有默认方式,但我们可以此命令改变Git的默认方式,此命令会从几个特定的配置文件中读取和写入配置值

- git help : 用于展示任何命令的Git自带文档,可以用 git help <command> 命令了解每一个命令的完整的可选项及标志列表

2、获取和创建项目

- git init : 用于将一个目录转变成一个Git仓库,成为Git仓库后就可以进行版本管理

- git clone : 此命令实际上是一个封装了其他几个命令的命令。 它创建了一个新目录,切换到新的目录,然后 git init 来初始化一个空的 Git 仓库, 然后为指定的 URL 添加一个(默认名称为origin 的)远程仓库(git remote add),再针对远程仓库执行 git fetch,最后通过 git checkout 将远程仓库的最新提交检出到本地的工作目录。

3、快照基础

- git add :  此命令将内容从工作目录添加到暂存区(或称为索引(index)区),以备下次提交。 当 git commit命令执行时,默认情况下它只会检查暂存区域,因此 git add 是用来确定下一次提交时快照的样子的。

- git status : 此命令会显示工作区及暂存区域中不同状态的文件。 其中包含了已修改但未暂存,或已经暂存但没有提交的文件。 在一般的显示形式中,它会给一些如何在这些暂存区之间移动文件的提示。

- git diff : 当需要查看任意两棵树的差异时,可以使用 git diff 命令。 此命令可以查看工作环境与暂存区的差异 (git diff 默认的做法),暂存区域与最后提交之间的差异(git diff --staged),或者比较两个提交记录的差异(git diff master branchB)。

- git difftool : 使用置的 git diff 命令时。git difftool 可以用来简单动一个工具来树 之间的差异。

 - git commit :   此命令将所有通过 git add 暂存的文件内容在数据库中创建一个持久的快照,然后将当前分支上的分支指针移到其之上。

 - git reset : 命令主要用来根据传递给动作的参数来执行撤销操作。 它可以移动 HEAD 指针并且可选的改变index 或者暂存区,如果使用 --hard 参数的话甚至可以改变工作区。 如果错误地为这个命令附加后面的参数,可能会丢失你的工作,所以在使用前要确定已经完全理解了它。

 - git rm :   Git 用来从工作区,或者暂存区移除文件的命令。 在为下一次提交暂存一个移除操作上,它与 git add 有一点类似。

 - git mv :  是一个便命令,用于移动一个文件在新文件上执`git add`命令及在文件上执`git rm`命令。

 - git clean : 是一个用来从工作区中移除不想要的文件的命令。 可以是编译的临时文件或者合并冲突的文件。

4、分支与合并

- git branch : 命令实际上是某种程度上的分支管理工具。 它可以列出所有的分支、创建新分支、删除分支及重命名分支。 git branch -u 用于设置一个跟踪分支。

- git checkout :  用来切换分支,或者检出内容到工作目录。 git checkout --track标志来开始跟踪分支

- git merge :  工具用来合并一个或者多个分支到已经检出的分支中。 然后它将当前分支指针移动到合并结果上。

- git mergetool :  当在 Git 的合并中遇到问题时,可以使用 git mergetool 来启动一个外部的合并帮助工具

- git log : 用于展示一个项目的可达历史记录,从最近的提交快照起。 默认情况下,它只显示当前所在分支的历史记录,但是可以显示不同的甚至多个头记录或分支以供遍历。 此命令通常也用来在提交记录级别显示 两个或多个分支之间的差异。

- git stash : 用于临时地保存一些还没有提交的工作,以便在分支上不需要提交未完成工作就可以清理工作目录。

- git tag : 用于为代码历史记录中的某一个点指定一个永久的书签,一般是用户发布的相关事项。

5、项目分享与更新

- git fetch :  用于与一个远程的仓库交互,并且将远程仓库中有但是在当前仓库的没有的所有信息拉取下来然后存储在本地数据库中。

- git pull :  此命令本上就是 git fetch 和 git merge 命令的Git 从指定的远程仓库容, 然后马并进所在的支中。

- git push :  此命令用来与另一个仓库通信,计算本地数据库与远程仓库的差异,然后将差异推送到另一个仓库中。 它需要有另一个仓库的写权限,因此这通常是需要验证的。

- git remote:  此命令是一个远程仓库记录的管理工具。 它允许将一个长的 URL 保存成一个简写的句柄,例如 origin ,这样就可以不用每次都输入他们了。 我们可以有多个这样的句柄,git remote 可以用来添加,修改,及删除它们。

- git archive:  此命令用来创建项目一个指定快照的归档文件。

- git submodule:  命令用来管理一个仓库的其他外部仓库。 它可以被用在库或者其他类型的共享资源上。submodule 命令有几个子命令, 如(add、update、sync 等等)用来管理这些资源。

6、检查与比较

- git show :  命令可以 以一种简单的人类可读的方式来显示一个 Git 对象。 一般使用此命令来显示一个标签或一个提交的信息。

- git shortlog :  一个用来归纳 git log 的输出的命令。 它可以接受很多与 git log 相同的选项,但是此命令并不会列出所有的提交,而是展示一个根据作者分组的提交记录的概括性信息。

- git describe :   命令用来接受任何可以解析成一个提交的东西,然后生成一个人类可读的字符串且不可变。 这是一种获得一个提交的描述的方式,它跟一个提交的 SHA-1 值一样是无歧义,但是更具可读性。

7、调试

- git bisect :   是一个非常有用的调试工具,它通过自动进行一个二分查找来找到哪一个特定的提交是导致bug 或者问题的第一个提交。

- git blame :   用于标注任何文件的行,指出文件的每一行的最后的变更的提交及谁是那一个提交的作者。 当要找那个人去询问关于这块特殊代码的信息时这会很有用。

- git grep :  命令可以帮助在源代码中,甚至是项目的老版本中的任意文件中查找任何字符串或者正则表达式。
 

8、补丁

- git cherry-pick :  命令用来获得在单个提交中引入的变更,然后尝试将作为一个新的提交引入到当前分支上。 从一个分支单独一个或者两个提交而不是合并整个分支的所有变更是非常有用的。

- git rebase :  基本是一个自动化的 cherry-pick 命令。 它计算出一系列的提交,然后再以它们在其他地方以同样的顺序一个一个的 cherry-picks 出它们。

- git revert :  命令本质上就是一个逆向的 git cherry-pick 操作。 它将提交中的变更的以完全相反的方式的应用到一个新创建的提交中,本质上就是撤销或者倒转。

9、邮件

很多 Git 项目,包括 Git 本身,基本是通过邮件列表来维护的。 从方便地生成邮件补丁到从一个邮箱中应用这些补丁,Git 都有工具来让这些操作变得简单。

- git apply :  应用一个通过 git diff 或者甚至使用 GNU diff 命令创建的补丁。 它跟补丁命令做了差不多的工作,但还是有一些小小的差别。

- git am :  用来应用来自邮箱的补丁。特别是那些被 mbox 格式化过的。 这对于通过邮件接受补丁并将他们轻松地应用到项目中很有用。

- git format-patch :  用来以 mbox 的格式来生成一系列的补丁以便可以发送到一个邮件列表中。

- git imap-send :  一个git format-patch 生成传至 IMAP 草稿文件

- git send-mail :  过邮件发送那些使用 git format-patch 生成的补丁。

- git request-pull :  简单的用来生成一个可通过邮件发送给某个人的示例信息体。 如果在公共服务器上有一个分支,并且想让别人知道如何集成这些变更,而不用通过邮件发送补丁,就可以执行此命令的输出 发送给这个你想拉取变更的人。

10、外部系统

Git 有一些可以与其他的版本控制系统集成的命令。

- git svn :  可以使 Git 作为一个客户端来与 Subversion 版本控制系统通信。 这意味着可以使用 Git 来检出内容,或者提交到 Subversion 服务器。

- git fast-import :  对于其他版本控制系统或者从其他任何的格式导入,可以使用 git fast-import 快速地将其他格式映射到Git 可以轻松记录的格式。

11、管理

- git gc :   在仓库中执行 “garbage collection”,删除数据库中不需要的文件和将其他文件打包成一种更有效的格式。此命令一般在背后为你工作,虽然可以手动执行它-如果想的话。

- git fsck :  用来检查内部数据库的问题或者不一致性。

- git reflog :  分析所有分支的头指针的日志来查找出在重写历史上可能丢失的提交。

- git filter-branch : 命令用来据某来重写大提交记录从任何地方文件,或者过过滤一个仓库中的一个取出一个目。

ps:学习成长路上的简单记录,若有不恰当之处,欢迎交流!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值