作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO
联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬
学习必须往深处挖,挖的越深,基础越扎实!
阶段1、深入多线程
阶段2、深入多线程设计模式
阶段3、深入juc源码解析
码哥源码部分
码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】
码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】
码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】
码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】
打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】
查看历史记录
#命令
git log
#多屏显示控制方式
空格向下翻页
b 向上翻页
q 退出
#每条日志显示一行
git log --pretty=oneline
#只显示一部分Hash值
git log --oneline
#HEAD@{移动到当前版本需要多少步}
git reflog
版本的前进和后退
-
基于索引值的操作
-
git reset --hard [局部索引值]
-
git reset --hard a6ace91
-
-
使用^符号:只能后退
- git reset --hard HEAD^
- 注:一个^表示后退一步,n个表示后退n步
-
使用~符号:只能后退
- git reset --hard HEAD~n
- 注:表示后退n步
reset命令的三个参数对比
- soft参数
仅仅在本地库移动HEAD指针 - mixed参数
在本地库移动HEAD指针,也会重置暂存区 - hard参数
在本地库移动HEAD指针,同时重置暂存区,重置工作区
删除文件并找回
- 前提:删除前,文件存在时的状态提交到了本地库
- 操作:git reset --hard [指针位置]
删除操作已经提交到本地库:指针位置指向历史记录
删除操作尚未提交到本地库:指针位置使用HEAD
比较文件差异
- git fiff [文件名]
将工作区中的文件和暂存区进行比较 - git diff [本地库中历史版本] [文件名]
将工作区中的文件和本地库历史记录比较 - 不带文件名比较多个文件