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中包含什么文件

相关推荐
崇山峻岭之间2 小时前
Matlab学习记录37
android·学习·matlab
开开心心_Every2 小时前
免费窗口置顶小工具:支持多窗口置顶操作
服务器·前端·学习·macos·edge·powerpoint·phpstorm
崇山峻岭之间2 小时前
Matlab学习记录38
学习
小+不通文墨2 小时前
“超声波测量声速”实验报告
经验分享·笔记·学习·学习方法
程序员果子3 小时前
GraphRAG:让大模型在知识图谱中精准导航
人工智能·git·语言模型·aigc·知识图谱
wubba lubba dub dub7503 小时前
第三十三周 学习周报
学习·算法·机器学习
代码游侠3 小时前
复习——ARM Cortex-A 裸机开发深度解析
arm开发·笔记·嵌入式硬件·学习·架构
小+不通文墨4 小时前
“示波器的调节和使用”实验报告
经验分享·笔记·学习·学习方法