我们主分支上面提交代码,我们使用git commit的命令进行提交,很简单,我在进行详细的描述。
分支
创建分支
我们通过实际操作看一下分支是什么样子的,比如说我们先要创建一个名字为newImage的分支。创建分支前:
data:image/s3,"s3://crabby-images/41ee3/41ee3696a8dfea2d39b8c8f0ea13eb331ad7ea86" alt=""
使用命令 git branch newImage
之后
data:image/s3,"s3://crabby-images/6d9c9/6d9c9a9d81891829dc9c9c0adc9cc9560547b1e6" alt=""
在新的分支上面提交内容
当我们向新的分支上面提交一些新的东西,如果我们直接执行git commit
。
data:image/s3,"s3://crabby-images/3eeae/3eeae17c541a376a26ffe11a6ca8bb1744225b6a" alt=""
我们会发现master分支前进了,但是newImage分支还是待在原地。我们仔细看一下上图,我们发现现在在master上面有一个星号,这表示的是我们现在在master分支上面。所以我们正确的操作是,先切换到新分支上面,然后进行提交代码,我们执行的命令是:
git checkout newImage ; git commit
data:image/s3,"s3://crabby-images/a2783/a278367df697aefe645bd5528a2165437f8cf764" alt=""
分支与合并
merge
假如我们现在有两个分支,每一个分支上面都有一个独立的提交记录。这就意味着没有一个分支包含我们所有的修改的内容,我们要将这两个分支进行合并,现在我们看一下分支的情况:
data:image/s3,"s3://crabby-images/aaf4c/aaf4cc15fbe34c3c281830160a9ba0510c6eb01e" alt=""
现在我们将bugFix合并到master分支上面,使用命令:git merge bugFix
data:image/s3,"s3://crabby-images/61d23/61d23280eb93525f0348115ad4e5a2be1da2f1f6" alt=""
但是我们希望将master 分支合并到bugFix上面,我们需要先进行分支的切换,然后在进行合并,具体的命令如:git checkout bugFix; git merge master
data:image/s3,"s3://crabby-images/fabe5/fabe584e1d8a35065e6501f6fec6fca39176f406" alt=""
上面这样执行的是因为master继承自bugFix,多以Git什么都不需要做,知识简单的把bugFix移动到master指向的那个提交记录就可以了。
rebase
我们要是想将bugFix分支直接移到master分支上面,移动以后会让两个分支的功能看起来像按顺序开发的,但是实际上他们是并行开发的
data:image/s3,"s3://crabby-images/2265f/2265f06aed3975d1129b56acd2d7859cb770cd3f" alt=""
我们执行git rebase master
,现在bugFix的分支上面的工作在master分支的最顶端,我们看一下C3依然存在,而C3'是我们Rebase到master分支上的C3副本,现在的问题是master还没有更新,我们线面进行master分支的更新。
data:image/s3,"s3://crabby-images/dcc7e/dcc7e5acd1e2bd0cddafa3d5581d2567bbff9a6a" alt=""
现在我们先切换到master分支上面,把它rebase到bugFix上面,合并的命令:git rebase bugFix
data:image/s3,"s3://crabby-images/2a170/2a170ed2603c137a1f7a66746a6712486ee4278c" alt=""
在提交树上移动
HEAD
HEAD是一个对当前检出记录的符号引用-- 也就是指向我们正在这个基础上进行工作的提交记录。
HEAD总是指向当前分支最近一次的提交情况。HEAD通常情况下指向分支名,在提交的时候,改变了分支的状态,这一改变导致HEAD是可见的。
data:image/s3,"s3://crabby-images/24135/24135a5d809ac8fddf3f63354eb3bfc7e3f92466" alt=""
执行命令:git checkout C1; git checkout master ;git commit; git checkout c2
data:image/s3,"s3://crabby-images/4e2d5/4e2d59de92efbb6f721a8b74692feba6d8a119f6" alt=""
分离的HEAD
分离的HEAD就是让其指向了某一个具体的提交记录,而不再是分支名
我们看一下现在的情况是:HEAD指向master,master指向c1
data:image/s3,"s3://crabby-images/322d1/322d108234248d72165aa4b15e60c5a360047c37" alt=""
如果我们使用指令git checkout C1
data:image/s3,"s3://crabby-images/e8561/e85615059680b7c707016f008d9d0ba9f1ddd554" alt=""
现在的执行变成了:HEAD指向C1
相对引用
- 我们可以使用^向上移动一个提交记录
- 使用^<num>向移动多个提交记录
data:image/s3,"s3://crabby-images/b58eb/b58ebc95003308c1075d1e0f5a3c010b3e3c974c" alt=""
我们可以看一下,根据上面的意思也就是master^ 就是master的父节点。
所以我们执行命令git checkout master ^
data:image/s3,"s3://crabby-images/85158/8515846398eaedf91a8688732ff03f6ee76a0bd0" alt=""
我们也可以将HEAD作为相对引用的参照,我们现在就举个栗子:
执行命令:git checkout C3; git checkout HEAD ^; git checkout HEAD ^; git checkout HEAD ^
执行命令前:
data:image/s3,"s3://crabby-images/ab941/ab941e1e4e2fbd9ecb8cf6fdc4dda0c39e1a9f3f" alt=""
执行命令后:
data:image/s3,"s3://crabby-images/0e928/0e928631f2eb039f2001d79a9fc5989b33b79bd5" alt=""
依次上移,直到:
data:image/s3,"s3://crabby-images/24fdf/24fdf7f90d5b83b347c24db8446f9b71ced0701f" alt=""
~操作符
如果在提交树上向上移动很多步骤的话,要敲很多的^,这样的就很麻烦,Git也考虑到了这一点,于是又引入先操作符~。
这个操作符后面可以和一个数字(可选,不跟数字时与^相同,向上移动一次),指定向上移动多少次。
后退之前:
data:image/s3,"s3://crabby-images/6757e/6757e8fffeb8abdc3b0ac17e883af0d2dc655bc0" alt=""
执行:git checkout HEAD~4
data:image/s3,"s3://crabby-images/61f6d/61f6d41d146f51d8c774ce9992be6f86281ca932" alt=""
我使用相对引用最多的就是移动分支,可以直接使用-f选项让分支指向另一个提交。
git branch -f master HEAD^3
:会将master分支强制指向HEAD的第3级父提交。
执行前:
data:image/s3,"s3://crabby-images/1c84b/1c84bd17871bdf8873daa7acd9e018d44f47b26e" alt=""
执行后:
data:image/s3,"s3://crabby-images/11974/11974b28353b0fe4dfa70a858fb997558aeda2d8" alt=""
网友评论