【前端面试】Git篇

git 的 reset 和 revert 的区别

  1. git reset
  • 作用对象:主要用于重置当前分支的HEAD指针,将分支指向指定提交或修改历史
  • 影响范围:直接修改提交历史,导致历史变得不一致,不适合在公共分支使用
  • 使用场景:适用于撤销本地的一些修改或操作
  1. git revert
  • 作用对象:用于创建一个新的提交,撤销指定提交或提交范围的修改,并将撤销的结果作为一个新的提交加入到历史中
  • 影响范围:不会修改提交历史,创建一个新的提交来撤销指定提交,适合在公共分支使用
  • 使用场景:撤销已经发布或共享的提交,如撤销错误提交、回滚线上发布等

git 的 merge 和 rebase 啥区别

  1. git merge
  • 工作原理:会创建一个新的合并提交,将要合并的分支更改和当前分支的更改合并在一起,创建一个新的提交记录
  • 特点:合并操作会在版本历史中保留原始分支的完整历史;不会改变提交的SHA标识,保存提交历史的完整性
  • 使用场景:多个开发者在同一个分支工作时,通常会使用合并来整合彼此的更改
  1. git rebase
  • 工作原理:会将变基的分支的提交移动到目标分支上,重新创建新的提交
  • 特点:会产生新的提交历史,就像在目标分支上顺序提交一样;会改变提交的SHA标识,改变提交历史结构
  • 使用场景:保持提交历史的清晰和线性时,会使用变基,还可以用于合并主分支到功能分支,并保持提交历史的整洁,避免出现不必要的合并提交

说一下 git rebase, git cherry-pick 的用法?

  • git rebase 用于将一个分支上的提交应用到另一个分支上,或者重新整理提交历史。它的一般用法如下:

    git checkout <target_branch>
    git rebase <source_branch>

这个命令将会将 <source_branch> 上的提交逐个应用到 <target_branch> 上,并且将 <target_branch> 移动到 source_branch 的最新提交上。

  • git cherry-pick 用于将指定提交应用到当前分支上。它的一般用法如下:

    git cherry-pick <commit_hash>

这个命令会将指定的 <commit_hash> 所对应的提交复制到当前分支上,并创建一个新的提交。

常用git命令

  • git clone:克隆远程仓库到本地
  • git init:将当前目录初始化一个新的Git仓库
  • git add:将文件添加到暂存区,准备提交
  • git commit -m "commit_message" :提交暂存区的改动到本地仓库,附带提交信息
  • git status:查看工作区、暂存区状态、显示文件修改情况
  • git diff:显示工作区与暂存区差异
  • git diff --staged:显示暂存区与最后一次提交的差异
  • git log:显示提交日志,包括提交哈希、作者、日期等信息
  • git branch:列出所有分支,当前分支前会有一个星号
  • git checkout:切换到指定分支
  • git checkout -b:创建并切换到新分支
  • git merge:将指定分支合并到当前分支
  • git pull:拉取远程仓库的更新并合并到当前分支
  • git push:将本地分支的更新推送到远程仓库
相关推荐
前端Hardy13 分钟前
前端工程师必备的 10 个 AI 万能提示词(Prompt),复制直接用,效率再翻倍!
前端·javascript·面试
BioRunYiXue17 分钟前
Nature Methods:CellVoyager 自主 AI 智能体开启生物数据分析新时代
大数据·开发语言·前端·javascript·人工智能·数据挖掘·数据分析
ノBye~36 分钟前
Docker Compose+Jenkins自动化部署全流程
git·docker·jenkins
再玉米地里吃过亏1 小时前
ONENET平台API鉴权错误
前端
网络点点滴1 小时前
Vue3中Suspense的使用
前端·javascript·vue.js
饼干哥哥1 小时前
搭建一个云端Skills系统,随时随地记录TikTok爆款
前端·后端
酉鬼女又兒2 小时前
零基础快速入门前端Web存储(sessionStorage & localStorage)知识点详解与蓝桥杯考点应用(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯·html
DanCheOo2 小时前
# 从"会用 AI"到"架构 AI":高级前端的认知升级
前端·ai编程
社恐的下水道蟑螂2 小时前
前端面试必问 Git 通关指南:常用命令速查 + merge/rebase 深度辨析,看完再也不慌
前端·git·面试
DanCheOo2 小时前
我写了一个 AI Commit Message 生成器,再也不用想怎么写 git commit 了
git·全栈