git reset

举报
王建峰 发表于 2021/11/19 01:30:42 2021/11/19
【摘要】 理解 1、git三棵树,即 HEAD,永远指向当前分支的最新一笔提交Index,索引(暂存区)Work Directory,工作目录 #git 底层命令 git cat-file -p HEAD ...

理解

1、git三棵树,即

  • HEAD,永远指向当前分支的最新一笔提交
  • Index,索引(暂存区)
  • Work Directory,工作目录
#git 底层命令
git cat-file -p HEAD 			#显示HEAD内容
git ls-tree -r HEAD 			#显示树对象的内容
git ls-files -s 				#显示索引(Index)的所有文件信息
tree 							#查看当前工作目录

  
 
  • 1
  • 2
  • 3
  • 4
  • 5

2、git-reset
将当前HEAD重置为指定状态。git help reset命令查看具体描述。

使用准则

  • 运行git --hard reset之前请考虑一下。如果由于执行这个选项导致工作目录中文件(文件已经提交)被覆盖,可以尝试git reflog找回。

命令速查

1、作用于某个patch

git reset --soft [patch]	#移动HEAD的指向,不改变Index和Work Directory
git reset --mixed [patch] #(默认reset)移动HEAD的指向,改变Index,但不改变Work Directory
git reset --hard [patch]	#移动HEAD的指向,改变Index和Work Directory

  
 
  • 1
  • 2
  • 3

2、作用于某个path/file

git reset [path/file]	#通过当前HEAD指向的patch改变当前Index(恢复暂存区)
git reset [patch] [path/file] #通过指定patch改变当前Index

  
 
  • 1
  • 2

3、压缩提交

git reset --soft [patch] #HEAD移动到压缩提交的前一个patch,Index和Work Directory不变
git commit #通过Index创建新的patch

  
 
  • 1
  • 2

###git reset 和 git checkout
总结了两点重要的区别,

  • 操作patch时,chekcout只移动HEAD指针本身(不改变HEAD分支)
  • 操作path/file时,checkout会改变工作目录(类似git reset --hard)

参考

文章来源: blog.csdn.net,作者:hinzer,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/feit2417/article/details/105012480

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。