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

相关推荐
vibecoding日记3 天前
为什么我就想要「线性历史 + Signed Commits」,GitHub 却把我当猴耍 🤬🎙️
git·编程工具
程序员小崔日记3 天前
如何将代码轻松上传到 Gitee?Git 使用全攻略!
git·gitee·上传
Bigger4 天前
为什么你的 Git 提交需要签名?—— Git Commit Signing 完全指南
git·开源·github
DianSan_ERP5 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
西岸行者5 天前
学习笔记:SKILLS 能帮助更好的vibe coding
笔记·学习
悠哉悠哉愿意5 天前
【单片机学习笔记】串口、超声波、NE555的同时使用
笔记·单片机·学习
别催小唐敲代码5 天前
嵌入式学习路线
学习
毛小茛5 天前
计算机系统概论——校验码
学习
babe小鑫5 天前
大专经济信息管理专业学习数据分析的必要性
学习·数据挖掘·数据分析