git stash

git stash误删恢复
今天写代码遇到一个小问题,代码未写完不想commit,但是要切换分支去处理任务,于是git stash 备份当前的工作区的内容。
没有进行

git stash apply 
git stash apply xxx

返回来,不小心使用错误命令:git stash drop(git stash clear),于是暂存的修改全部没有了。
于是,通过命令git fsck –lost-found找到最近的一些删除的提交,其实自己删除的id号前面命令行是有的,
找到abf709*,然后git show abf709*查看修改情况,git merge abf709 或者git stash apply abf709即可修复删除掉的内容了。
git stash pop,不同于git stash apply, 会应用且pop出最近的一次stash,stash list不再会有之前的stash。git stash pop出的change是可以找回的.
1.每次git stash都会生成一个新的commit,只要知道commitID, 通过git stash apply commitID 就可以应用之前的stash,然后重新git stash, 那么新修改就
回到了stash list中。寻找commitID有两种方法:

2.git stash pop 最后会打印出pop掉的commitid值,若这个记录还存在直接使用即可。
git fsck, 会打印出所有的dangling commit, 悬挂的commit是不被任何branch引用的commit。 一般list出的第一个commit即是刚刚被pop掉的commit。也可通过查看commit在commit graph中的位置确定对应的commitID:
git log --graph --oneline (git fsck | awk '/dangling commit/ {print3}')

git使用了这么久,其实还是有很多东西没能深入了解,比如blob,tree,tag和commit都代表了什么含义,各有什么作用,查找了一些资料,学习记录一下。
每个object包含三个部分:类型,大小和内容。大小就是指内容的大小,内容取决于对象的类型,有四种类型的对象,也就是上面提到的blob,tree,tag和commit。

blob用来存储文件数据,通常是一个文件

tree有点像一个目录,它管理一些tree或blob,就像文件和子目录

tag标签,用来标记某一次的commit

commit只指向一个tree,它用来标记项目某一个特定时间点的状态。它包括一些关于时间点的元数据,比如时间戳、最近一次提交的作者,指向上次提交的指针等等。
参考链接https://stackoverflow.com/questions/89332/how-to-recover-a-dropped-stash-in-git

Git如何stash部分文件

今天工作的时候有这样一个诉求,改了本地大量的代码,但是有两个文件是适配本地的配置文件不需要上库,如果git commit [filename]的话需要写很多文件,很不方便,于是使用了stash方法,这里做个记录.

首先解释下git stash的作用,git stash是将本地没有commit的部份全部存储起来,这样方便你进行pull之类的操作,具体可以参考Git 工具 - 储藏与清理.

但是如果直接git stash的话,会将当前所有文件都存储起来,而我只想存储两个配置文件,其他的全部一起commit,这应该怎么办呢?这里需要用到一个git stash -p的命令;它是一个交互式命令,我们可以一个文件一个文件的遍历,决定每个文件的操作方式.

root /u/c/s/cbs (master)# git stash -p
diff --git a/cmd/scripts/cbs.sh b/cmd/scripts/cbs.sh
old mode 100644
new mode 100755
Stash mode change [y,n,q,a,d,/,?]? 

这里的[y,n,q,a,d,/,?]分别代表的含义如下:

   y - stage this hunk
   n - do not stage this hunk
   q - quit; do not stage this hunk nor any of the remaining ones
   a - stage this hunk and all later hunks in the file
   d - do not stage this hunk nor any of the later hunks in the file
   g - select a hunk to go to
   / - search for a hunk matching the given regex
   j - leave this hunk undecided, see next undecided hunk
   J - leave this hunk undecided, see next hunk
   k - leave this hunk undecided, see previous undecided hunk
   K - leave this hunk undecided, see previous hunk
   s - split the current hunk into smaller hunks
   e - manually edit the current hunk
   ? - print help

所以,遇到我们需要stash的文件,我们就y,不需要stash需要commit的文件,我们就n,如果接下来没有需要stash的文件,则直接q退出就行.

将文件保存好后,我们就可以commit和push剩下的代码了.

git commit -m ""
git push origin master

然后我们将stash的文件恢复到本地,所有的操作就完成了.

git stash pop
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • git stash内容误删找回 开发工作中,git是我们最常用的工具之一。最近我在开发中遇到这么一个问题:某次的开...
    楚丶liu香阅读 13,743评论 0 4
  • git 使用笔记 git原理: 文件(blob)对象,树(tree)对象,提交(commit)对象 tree对象 ...
    神刀阅读 9,165评论 0 10
  • Add & Commit git init 初始化一个 Git 仓库(repository),即把当前所在目录变成...
    冬絮阅读 10,403评论 0 9
  • 你,怕鬼吗 如果你怕,那你一定相信它的存在对吧 可为什么你宁愿相信有鬼,确不想想还有神的存在呢 你相信什么,你愿意...
    我即王法阅读 1,189评论 0 0
  • 月亮! 为什么对我冷冰冰? 我渴望每天见到你, 你却, 任云彩遮盖你的光辉, 凭群星夺走你的灿烂…… 没有你的夜空...
    听云吹风2阅读 1,004评论 2 1

友情链接更多精彩内容