Git基础(二)(完结)

Git分支概念

暂存操作:计算每一个文件的校验和,然后使用每一个blob对象保存文件快照,最终将校验和放入暂存区。

commit操作:计算每一个子目录的校验和,将这些校验和保存为树对象。然后git创建一个包含指向树对象的指针的提交对象。

 

提交对象包含提交信息、树对象指针、指向上次提交对象的指针。

 

git的分支即指向提交对象的可变指针。

 

HEAD指针为指向当前分支的指针,用来确认当前所在分支。

 

Git分支操作命令

 

查看当前分支列表

git branch

ps:查看当前分支,以及每一个分支的最后提交。

ps:git branch --merged查看合并到当前分支的分支列表。

ps:git branch --no-merged查看未合并到当前分支的分支列表。

 

创建分支

git branch kkk

note:创建名为kkk的指针。

 

分支切换

git checkout sss

note:切换到名为sss的指针。

ps:切换分支之后,会将工作目录恢复至指定分支指向提交记录时的工作目录状态。

ps:git log --oneline --decorate --graph --all 查看各个分支指向以及分支分叉情况。

ps:git checkout -b ccc,新建分支ccc,并且切换到此分支。

 

合并分支

git merge kkk

note:将当前分支与kkk合并。

ps:如果被合并的分支为当前分支的下游结点,那么当前分支的指针直接指向被合并分支指向的提交记录,此行为称为快进。

ps:合并的分支与当前分支如果对同一个文件修改有冲突,那么冲突的文件需要处理冲突然后暂存。

ps:冲突的部分会被<<<===>>>圈出。

 

删除分支

git branch -d ccc

note:将分支ccc关闭删除。

 

查看所有远程分支

git remote show origin

note:查看远程仓库origin拥有的全部远程分支。

 

创建一个跟踪分支

git checkout -b ccc origin/kkk

note:新建并移动到一个新建分支ccc,而且此分支跟踪远程分支origin/kkk。

note:git checkout --track new/ssss 创建一个名为ssss的分支跟踪远程分支new/ssss。

 

删除远程分支

git push origin --delete sss

note:将远程仓库origin中的远程分支sss删除。

 

变基

git rebase kkk

note:将当前分支变基到kkk分支上。

ps:找到当前分支与变基操作的目标基底分支的最近共同祖先节点,然后将当前分支相对于此祖先的历次提交,提取修改并暂存为临时文件,将当前分支指向目标基地分支,然后将之前另存为的临时文件的修改依序应用。

ps:变基操作与合并操作的效果相同,但是历史为线性,更整洁。

ps:不要对仓库外有副本的分支进行变基。如果真的发生了,可以使用,git rebase orgin/ccc,令当前分支针对远程仓库origin中被变基的ccc分支进行变基。

ps:git pull等价于git fetch与get merge,如果使用git pull达成变基效果,可以使用git pull --rebase origin/xxx。

 

详细学习:https://git-scm.com/book/en/v2

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值