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

相关推荐
九成宫6 分钟前
Git 与远程仓库实操记录:克隆、配置、分支推送与问题排查
笔记·git·ssh
MegaDataFlowers1 小时前
英语六级我还在背单词:Unit 1(Lesson 2)
学习
东京老树根1 小时前
SAP学习笔记 - BTP SAP Build12 - SAP Build Content Package
笔记·学习
幸福巡礼4 小时前
【LangChain 1.2 实战(一)】 概述
笔记·学习·langchain
知识分享小能手5 小时前
R语言入门学习教程,从入门到精通,R语言数据计算与分组统计(9)
开发语言·学习·r语言
lizhihai_995 小时前
股市学习心得—半导体12种核心材料
大数据·人工智能·学习
sakiko_6 小时前
UIKit学习笔记3-布局、滚动视图、隐藏或显示视图
前端·笔记·学习·objective-c·swift·uikit
嵌入式-老费6 小时前
瑞芯微soc的学习和应用(题外话之esp32开发)
学习
辰同学ovo7 小时前
从全局登录状态管理学习 Redux
前端·javascript·学习·react.js
ting94520007 小时前
告别无效学习:Scholé 如何用 AI 重构职场学习,让学习直接嵌入工作流
人工智能·学习·重构