git常用命令与概念汇总

news/2024/6/18 20:29:55 标签: git

设置记住用户名和密码

# --global如果不加则只针对当前项目
# 设置之后需要重新pull一下代码,然后提示输入用户名密码后会自动保存,从而实现记住用户名和密码的目的。
# 这样设置的用户名和密码是以明文的方式存储的。比如你安装了一个Npm包,这个包有可能有权限读取这个文件。
git config --global credential.helper store

关于删除某次提交的做法

首先可以使用revert,即对某一次提交的修改原封不动的改回去,当然某一次提交之后若有修改这次提交的代码,是会产生冲突的。值得注意的是,这样的修改会保留原有的提交记录不动,并产生一次新的提交。

其次可以使用rebase -i 进入交互式命令行,从而删除一次或多次提交。但如果删除的提交的某一行(相当于回滚的一行)与之后的提交操作了同一行(相当于修改要被回滚的行),此时仍旧会产生冲突。

这样看来,如果你想删除某次提交,而这个提交改动的东西和之后的提交改动的是同一行,无论如何也无法避免冲突的。

HEAD的意思

简单来说,HEAD可以理解为一个引用,指向当前本地的代码的所在分支的所在提交。

下图中,当前分支为master,当我创建新分支testing的时候,其实仅仅是创建了一个引用。

$ git branch testing

在这里插入图片描述
那么如何得知我当前到底在master还是testing上?这就是需要HEAD的地方。
在这里插入图片描述

当你使用如下命令的时候,HEAD则会指向testing

$ git checkout -b testing

可以说,当我们使用checkout的时候,也就是在branch或者commit之间切换的时候,HEAD会跟随着改变。但如果checkout出来的不是当前分支的最新一次提交,那么此时HEAD就称为detached HEAD

detached HEAD

一般情况下,我们并不会遇到detached HEAD,除非我们要检出某一次提交看看那时候的代码是什么样子的,但理想的做法是检出那一次提交的tag

但如果我们检出的提交即没有分支引用也没有tag引用,那么在此基础上做的修改并提交,会导致这个提交只有HEAD指向。

   HEAD (refers to commit 'b')
    |
    v
a---b---c---d  branch 'master' (refers to commit 'd')
    ^
    |
  tag 'v2.0' (refers to commit 'b')

经历一次提交,但新的提交未在任何分支上,仅有一个HEAD指向

     HEAD (refers to commit 'e')
      |
      v
      e
     /
a---b---c---d  branch 'master' (refers to commit 'd')
    ^
    |
  tag 'v2.0' (refers to commit 'b')

如果在此基础上将HEAD重新指向master(git checkout master),则会导致e这个这个提交被git的垃圾回收器回收。(试想一下,branch也是对一个commit的引用,为什么删除了branch这个引用,整个分支都删除了?)

想解决这个问题,只需HEAD还没切换到其他分支的之后,执行类似如下的命令(三选一即可):

$ git checkout -b foo   (1)
$ git branch foo        (2)
$ git tag foo           (3)

官方文档解释的更细致。

Git HEAD ^ 与 ~

  • HEAD指代当前本地检出的分支或提交
  • ~表示HEAD的第一父级(的第一父级(的第一父级))。
  • ^是第一(或者第二)父级,因为合并的提交会有两个父级。

以上每个父级当然是指一次提交。

见下图:

  • ~ 意思很清楚,也是会经常使用的到的,仅仅是指当前分支。
  • ^ 代表第几个父级,比如蓝色的提交可以解释为:最新一次提交的第一父级的第二父级HEAD~1^2
    在这里插入图片描述
    再次说明,无论是HEAD,还是HEAD和~^的各种组合,均是指某一次提交,相当于是一种相对路径,更方便的找到想找的某一次提交。

RESET

我不想要我的这次提交了…

如果说git checkout可以在提交中切换,那么reset就是在切换之后,对已经提交的代码如何处理。以参数的形式指明如何对待你已经提交的代码。

  • --hard 删了不要
  • --soft 留在暂存区
  • --mixed留在工作区

这个图经典的解释了三种模式的区别:
在这里插入图片描述

未完待续~~


http://www.niftyadmin.cn/n/1382694.html

相关文章

CentOS6 Shell脚本/bin/bash^M: bad interpreter错误解决方法

为什么80%的码农都做不了架构师?>>> 在windows下保存了一个脚本文件,用ssh上传到centos,添加权限执行nginx提示没有那个文件或目录。shell脚本放到/etc/init.d/目录下,再执行/etc/init.d/nginx,提示多了这…

[并查集] hihocoder 1158 质数相关

题目大意 题目链接,定义两个数\(a,b\)质数相关满足 \(ba\times p\), 且\(p\)是质数。给定数组,问最大质数无关子集大小。 算法思路 首先想到的是将每个数看作一个顶点,质数相关的两个数之间连边,求最大独立子集。但是最大独立子集…

Spring Cloud 微服务的那点事

在详细的了解SpringCloud中所使用的各个组件之前,我们先了解下微服务框架的前世今生。 单体架构 在网站开发的前期,项目面临的流量相对较少,单一应用可以实现我们所需要的功能,从而减少开发、部署和维护的难度。这种用于简单的增删…

Swift - 类扩展(extension)

(本文代码已升级至swift3)Swift语言的类扩展是一个强大的工具,我们可以通过类扩展完成如下事情: 1,给已有的类添加计算属性和计算静态属性2,定义新的实例方法和类方法3,提供新的构造器4&#xf…

[vue-router] uncaught error during route navigation

vue路由在加载组件之前会执行一些逻辑,尤其是生命周期的钩子函数 如果你在以上的钩子函数中,写了自己的逻辑,并报错了。就会触发[vue-router] uncaught error during route navigation这个错误。 原因是vue进行了try catch,会捕…

dajango 模板中 js 使用服务器返回的数据

var data "{{ line|safe }}"明确告诉django不要逃避该变量的输出Django的模板中会对HTML标签和JS等语法标签进行自动转义,原因显而易见,这样是为了安全。但是有的时候我们可能不希望这些HTML元素被转义,比如我们做一个内容管理系统…

Reddit重写其iOS应用,改进性能、模块化和测试

去年,Reddit一直在努力改进其iOS应用的性能,同时使其适合更快的迭代周期,改善其测试覆盖率,提高其可扩展性。所有这些都是通过把应用原来的MVC架构改造成Model-View-Presenter(MVP)架构实现的。\\原来的MVC…

关于java中string的内存位置

java运行时内存分五部分: 线程共享:堆内存、方法区(包括常量池) 线程私有:栈内存、本地方法栈、程序计数器 string不是基本数据类型,那么一个string的内存位置是什么呢?一共有两种情况&#xff…