Git学习记录

1、Git中的基本概念

  • workspace:工作区(当前写代码的)
  • staging area:暂存区/缓冲区
  • local repository:本地仓库
  • remote repository:远程仓库

2、Git分支管理

Git分支管理可以从主线上分离开,不受影响。

2.1 创建分支

1、git checkout -b

example:git checkout -b "feature-new"

创建一个名字叫feature-new的分支,从本地仓库当前执行命令的分支拉一条新的分支,内容一致

2、git branch

查看当前仓库中所有分支

3、reset

回退到其他历史commit版本

git reset --参数名 commitId

例如:git reset --hard abc123

参数 版本库 (HEAD) 暂存区 (Index) 工作区 (Workdir) 适用场景
--soft 回退到指定 commit 保留(保持已 add 状态) 保留 想撤销 commit,但保留修改并重新提交
--mixed 回退到指定 commit 重置(变回未 add 状态) 保留 想撤销 commit 和 add,重新挑选文件提交
--hard 回退到指定 commit 重置(全部清空) 重置(全部清空) 慎用! 彻底放弃所有修改,回到过去状态
--keep 回退到指定 commit 重置 受保护地保留 安全版 hard,如果本地有冲突则拒绝重置

soft会把add保留但是commit会撤销

mixed会把commit撤销,add也会被撤销

hard,全部清空,回到当前commit的最原始状态,意味着所有更改全部清空

例子:

问题:我现在提交一个错误的commit,我需要把他回退,

使用

1、使用git log 查看历史

git log --oneline -n 5 // 一行查看历史

2、git reset

git reset --mixed commitId或者HEAD~1

git reset --mixed commitId之后会提示,当前没有暂存的文件,因为mixed是把add也重置了,同时commit历史也没有了错误提交的那一版本commit

4、stash

git stash ,将当前更改暂存,会清空当前工作区的代码,

git stash pop 还原暂存区代码到现在的提交历史,干净,用于紧急修复功能和需求开发分离。

git stash list,暂存区历史。

git stash save "重构到一半的代码文件"

5、push

git push -u MyMusicDemo master

远程仓库第一次推送需要-u(等价--set-upstream),目的是建立本地分支与远程分支的绑定关系

之后就可以推送上去了

6、rebase

git rebase master dev

或者

git checkout dev

git rebase master

将master分支的最新代码合并到dev中去,git历史是线性的。

问题:和merge有什么区别呢?少了无关的日志?更简洁一点。

答:现在在dev上开发,拉取的是旧的master的某个commitId,现在master更新了,dev也更新了,把他们合并到一起去,让提交历史是线性的。

rebase过程中会遇到冲突,也就是解冲突之后的代码才能合并到一块。

通俗解释

rebase,变基,改变基底。feature分支基于master分支的B节点拉取的,feature的基底是B。master在B之后有新的提交,此时想用master上新的提交作为feature分支的新基底。

实际操作就是把B之后的feature提交先暂存,再删除原本的提交,再找到master最新的提交位置,把暂存下来的提交再提交接上去(需要逐个和新的基底进行解冲突),此时feature新基底就不再是B了,变成了M。(如果此时master没有新提交,就还是原本的B作为基底,rebase无效,唯一和merge的区别就是少一条merge提交记录。)

坏处就是历史从哪里来的会消失

链接:
rebase详解

案例

问题:我目前有一个需求来了,开发过程中出现了一个需要紧急修复的bug,我应该怎么做,不影响两个开发的过程?

答:

1、首先git stash save "重构代码" 暂存目前正在开发的需求代码。

2、目前工作区的代码是最近一次提交,紧急修复之后

git add . ---> git commit -m "hotfix修复" ---> git push -u 仓库名 分支名

修复推送完成后

3、git stash pop 还原到当前新需求代码继续开发。

问题:

1、git中的四个操作区域分别代表什么?

2、四个操作区域使用什么指令。

3、.git中包含什么文件

相关推荐
执笔论英雄8 小时前
【大模型学习cuda】入们第一个例子-向量和
学习
wdfk_prog8 小时前
[Linux]学习笔记系列 -- [drivers][input]input
linux·笔记·学习
李少兄8 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
Gary Studio10 小时前
rk芯片驱动编写
linux·学习
mango_mangojuice10 小时前
Linux学习笔记(make/Makefile)1.23
java·linux·前端·笔记·学习
lingggggaaaa10 小时前
安全工具篇&动态绕过&DumpLsass凭据&Certutil下载&变异替换&打乱源头特征
学习·安全·web安全·免杀对抗
PP东11 小时前
Flowable学习(二)——Flowable概念学习
java·后端·学习·flowable
学电子她就能回来吗11 小时前
深度学习速成:损失函数与反向传播
人工智能·深度学习·学习·计算机视觉·github
AI视觉网奇13 小时前
ue 角色驱动衣服 绑定衣服
笔记·学习·ue5
wdfk_prog14 小时前
[Linux]学习笔记系列 -- [drivers][input]serio
linux·笔记·学习