【Git】git checkout

本文详细介绍了Git的checkout命令,包括切换分支、恢复文件、创建临时分支等操作。通过实例解析了如何使用gitcheckout进行版本回溯和实验性修改,并讨论了临时分支的使用场景及其与原分支的关系。了解这些内容有助于提升Git操作效率和版本管理能力。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

checkout命令,即"检出",用于从历史提交(或者暂存区域)中拷贝文件到工作目录,也可用于切换分支。

1. 常用命令

1、git checkout

表示核查工作区相对于版本库修改过的文件

2、git checkout + 分支名

表示切换分支

3、git checkout -b 分支名

表示以当前分支的当前状态创建新分支并切换到新分支 -b 表示创建新分支

4、git checkout -b 分支名 commitID

表示以当前分支的commitID提交节点创建新的分支并切换到新分支。此时工作区的内容和切换分之前commitID提交节点的内容一样

5、git checkout commitID

是以指定的提交节点创建了一个临时性分支,此临时性分支可用于做实验性修改

6、git checkout filename

当没有提交版本号时将工作区的指定文件的内容恢复到暂存区的状态

7、git checkout .

将工作区的所有文件的内容恢复到暂存区的状态

8、git checkout <commit> filename

当有提交版本号时,表示将工作区和暂存区都恢复到版本库指定提交版本的指定文件的状态,此时HEAD指针不变,此时的状态相当于把工作区的内容修改到指定版本的文件内容后,再把修改的内容添加到暂存区。因此git checkout <commit> filename后,可以直接执行git commit而不需要先执行git add

9、git branch -d branch_name
删除分支

2. 实操

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
5、 git checkout commitID 此命令有些特殊,此命令执行后,工作区的内容会变成commitID提交节点的内容,但时HEAD不位于任何分支上,处于游离状态。

更准确的说,此命令是以指定的提交节点创建了一个临时性分支,被别HEAD指向了这个临时分支,你可以在这个临时分支上修改内容并且提交内容。

但是,一但你从临时分支切换到其他分支,这个临时分支就会消失。

这种临时性分支主要用来做一些实验性的修改,实验结束后,只要切换回原分支即可,原分支不会有任何改变。临时性分支上的改动并不会反映到原分支。

但是你如果想把这临时性分支上的改动反映到原分支上,可以通过git checkout -b 新分支名 命令 以临时性分支的当前状态创建一个永久性分支,再把这个分支合并到原先的分支,然后再删除这个分支即可。

执行git checkout commitID命令

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

InceptionZ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值