git checkout 切 commit

简介: git checkout 切 commit

切换分支是 git checkout 最常见的功能,这里不做介绍,今天主要介绍下它在撤销文件改动上的应用。

// 放弃单个文件修改,注意不要忘记中间的"--",不写就成了检出分支了
git checkout -- filepathname
// 放弃所有的文件修改
git checkout .  

此命令用来放弃掉所有还没有加入到缓存区(就是 git add 命令)的修改。但是此命令不会删除掉刚新建的文件。因为刚新建的文件还没已有加入到 git 的管理系统中。所以对于git是未知的。自己手动删除就好了。

git checkout 切换到指定 commit:

git chekcout <commit>

上面的命令是回滚到工作目录中指定的 commit 上,这是一个只读操作,不会影响到当前工作区的状态,它在你查看旧版本的文件时不会损坏你的代码仓库。

HEAD 是一个指针,通常情况下,它指向当前所在分支,而分支又指向一个 commit 提交。HEAD 并不总指向一个分支,某些时候仅指向某个 commit 提交,这就形成 detached HEAD。

切换到 detached HEAD 状态时,会有一个警告。
在这里插入图片描述
你可以任意的更改任意的提交,通过切换回分支而不影响任何分支的状态。当你切回分支的时候在这里留下的提交你就相当于放弃了。

在你没切走之前,可以创建一个新分支来保留所创建的提交,则可以通过在 switch 命令中使用 -c 来执行此操作:

git switch -c <new branch name>

如果你没有执行上面的命令,当你切走之后,会有一个警告。
在这里插入图片描述

在 detached HEAD 状态下开发新的 feature,将没有任何办法引用到这个 feature。你可以把 detached HEAD 状态看作是正在一个未命名的分支上。你只需要给这个分支命名就可以使用这个 feature 了,然后就可以把这个新分支上的代码合并到其他分支上了,通过命令:

git branch <new-branch-name> 588f5c0

假设你正在进行一次疯狂的重构,但现在你不确定是否要继续下去。这时你想要看一下开始这次重构之前项目原来的样子,首先你需要查看版本的ID,然后使用 git checkout 切换到这个之前的版本。

git checkout a1e8fb5

这让你的工作区切换到了 a1e8fb5 comimit 的状态。你可以查看文件、编译项目、运行测试用例,甚至编辑文件,完全不用担心丢失项目“当前”的状态,你在这里做的所有修改都不会被保存到项目中。当你想要继续那次疯狂的重构时,你需要回到项目的“当前”状态。

git checkout master
相关文章
|
6月前
|
人工智能 缓存 开发工具
结合企业实践来规范你的Git commit(含插件使用指南)
结合企业实践来规范你的Git commit(含插件使用指南)
结合企业实践来规范你的Git commit(含插件使用指南)
|
6月前
|
开发工具 git
git checkout (branchname
git checkout (branchname) 是 Git 中切换分支的一种命令。通过这个命令,你可以将当前工作目录切换到指定的分支上。branchname 参数是可选的,如果不指定,则默认切换到主分支(master 或 main)。
133 2
|
6月前
|
开发工具 git
Git Commit Msg
Git Commit Msg
71 0
|
6月前
|
JSON 开发工具 git
git rebase 合并当前分支的多个commit记录
git rebase 合并当前分支的多个commit记录
125 1
|
2月前
|
开发工具 git
GIT:如何合并已commit的信息并进行push操作
通过上述步骤,您可以有效地合并已提交的信息,并保持项目的提交历史整洁。记得在执行这些操作之前备份当前工作状态,以防万一。这样的做法不仅有助于项目维护,也能提升团队协作的效率。
144 4
|
2月前
|
开发工具 git
GIT:如何合并已commit的信息并进行push操作
通过上述步骤,您可以有效地合并已提交的信息,并保持项目的提交历史整洁。记得在执行这些操作之前备份当前工作状态,以防万一。这样的做法不仅有助于项目维护,也能提升团队协作的效率。
235 3
|
6月前
|
开发工具 git 开发者
|
3月前
|
开发工具 git
Git——commit的提交规范
Git——commit的提交规范
102 4
|
3月前
|
测试技术 持续交付 开发工具
[译] 为何每次 Git Commit 要尽可能小?
[译] 为何每次 Git Commit 要尽可能小?
|
3月前
|
Java 开发工具 Android开发
Android Studio利用Build.gradle导入Git commit ID、Git Branch、User等版本信息
本文介绍了在Android Studio项目中通过修改`build.gradle`脚本来自动获取并添加Git的commit ID、branch名称和用户信息到BuildConfig类中,从而实现在编译时将这些版本信息加入到APK中的方法。
71 0