如果我有N个提交,我如何从N-3个提交分支?
当前回答
转到git存储库的特定提交
有时,在处理git存储库时,您希望返回到特定的提交(修订),以便在特定的时间获得项目的快照。要做到这一点,您需要提交的SHA-1哈希,您可以使用以下命令轻松查看日志:
git log --abbrev-commit --pretty=oneline
这将为您提供所有提交和SHA-1哈希的简短版本的紧凑列表。
现在您知道了要转到的提交的哈希值,可以使用以下2个命令之一:
git checkout HASH
or
git reset --hard HASH
结账
git checkout<commit><path>
告诉git将路径的当前状态替换为给定提交中的状态。路径可以是文件或目录。
如果没有给出分支,git将接受HEAD提交。
git checkout <path> // restores path from your last commit. It is a 'filesystem-undo'.
如果没有给定路径,git将HEAD移动到给定的提交(从而更改您正在进行的提交)。
git checkout branch //means switching branches.
重置
git reset <commit> //re-sets the current pointer to the given commit.
如果您在一个分支上(通常应该是),HEAD和这个分支将被移动到提交。
如果您处于分离HEAD状态,git reset只会移动HEAD。要重置分支,请首先检查它。
如果你想了解更多关于git重置和git结账的区别,我建议你阅读git官方博客。
其他回答
这将使用一个命令创建分支:
git push origin <sha1-of-commit>:refs/heads/<branch-name>
我更喜欢这种方式,因为它会立即创建分支(之后不需要额外的push命令)。
使用Sourcetree|最简单的方法。
首先,签出要进行特定提交以创建新分支的分支。然后查看工具栏,选择Repository>Branch。。。快捷方式是Command+Shift+B。然后选择要执行的特定提交。并给出一个新的分支名称,然后创建一个分支!
魔法可以通过git重置来实现。
创建一个新的分支并切换到它(因此所有最新的提交都存储在这里)git结帐-b your_new_branch切换回以前的工作分支(假设它是主分支)切换到主分支删除最新的x个提交,保持master干净git reset--hard HEAD~x#在您的情况下,x=3
从这一刻起,所有最新的x提交都只在新分支中,不再在上一个工作分支(master)中。
如果您不确定要提前从哪个提交分支,可以检查提交并检查其代码(参见源代码、编译、测试)
git checkout <sha1-of-commit>
一旦找到了要从中分支的提交,就可以在提交中(即,不必先返回到主提交),只需按通常的方式创建一个分支:
git checkout -b <branch_name>
对于GitGUI用户,您可以可视化所有历史记录(如果需要),然后右键单击要分支的提交并输入分支名称。
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- 在GitHub上有一个公共回购的私人分支?
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式