git-2

1.分离头指针情况下的注意事项

分离头指针指的是变更没有基于某个branch去做,所以当进行分支切换的时候,在分离头指针上产生的commit,很可能会被git当作垃圾清理掉,如果你认为是重要的内容,切记需要绑定分支

2.进一步理解HEAD和branch

git checkout -b fix_readme fix_css 在fix_css分支上创建新分支,并切换到改分支

HEAD最终会落脚于某个commit,不管处于分离头状态还是HEAD指向分支的最新一次提交的commit

HEAD

HEAD^ (HEAD~1)代表HEAD的父亲

HEAD^^ (HEAD~2)代表HEAD父亲的父亲

3.怎么删除不需要的分支?

一般-d 删除,如果报没有被merge,则用-D 进行删除分支

4.怎么修改最新commit的message?

git commit --amend 修理一下

对最近一次提交的commit做变更

5.怎么修改老旧commit的message?

发展分支上的任何一个commit 进行调整,用rebase,前提是这些变基行为是在自己的分支上做变更,还没有贡献到团队的集成分支上,如果已经在集成分支上,就不能随意的变基

git log -3 最近3次提交

基于父亲文件进行

git rebase -i 选择被变的父亲 其中-i交互式

修改后进行保存,保存后会自动跳转新的页面

6.怎样把连续的多个commit整理成1个?

把之前不清晰的更改成更加清晰的commit

下面是git rebase -i cb3ca9451f5cbdb 之后的结果

自动跳转到新的页面

7.怎样把间隔的几个commit整理成1个?

8.怎么比较暂存区和HEAD所含文件的差异?

git diff --cached 暂存区和HEAD的差异

9.怎么比较工作区和暂存区所含文件的差异?

指定几个文件就可以比较几个文件的差异

git diff 默认比较工作区和暂存区的区别

git diff 把所有的差异都展示出来

git diff -- 文件名 是对具体文件的差异展示出来

git diff -- 文件名1 文件名2 文件名3 可以是多个文件的差异

10.如何让暂存区恢复成和HEAD的一样?

git reset 更强大,可以修改提交历史和分支引用,而git reset 更专注于工作区和暂存区的文件还原

git diff --cached 返回为空,则表明暂存区和工作区一致

git reset HEAD 暂存区所做的变更不想要了,一刀切,恢复成现在最新的分支commit,也就是HEAD指向的这些文件的模样

相关推荐
diving deep1 小时前
IDEA中git对于指定文件进行版本控制
git
趁你还年轻_4 小时前
记录一次git提交失败解决方案
git
关于不上作者榜就原神启动那件事7 小时前
git版本控制学习
git·学习
Cchaofan14 小时前
Git/GitLab日常使用的命令指南来了!
git·gitlab
可乐加.糖21 小时前
项目版本管理和Git分支管理方案
java·git·目标跟踪·gitlab·敏捷流程·源代码管理
wingaso21 小时前
[经验总结]删除gitlab仓库分支报错:错误:无法推送一些引用到“http:”
linux·数据仓库·git
ice___Cpu1 天前
Git - 1( 14000 字详解 )
大数据·git·elasticsearch
范纹杉想快点毕业2 天前
以项目的方式学QT开发(一)——超详细讲解(120000多字详细讲解,涵盖qt大量知识)逐步更新!
c语言·数据结构·c++·git·qt·链表·github
qq_653644462 天前
如何查看打开的 git bash 窗口是否是管理员权限打开
开发语言·windows·git·bash
tonngw2 天前
【Mac 从 0 到 1 保姆级配置教程 12】- 安装配置万能的编辑器 VSCode 以及常用插件
git·vscode·后端·macos·开源·编辑器·github