Java技术八股学习Day36

Git

版本控制核心概念

(1)定义与价值

版本控制是记录文件 / 项目内容变化的系统,支持回溯历史版本、对比修改差异、定位问题根源,适配个人开发与团队协同场景。

(2)三类版本控制系统
  • 本地版本控制系统:基于本地数据库记录文件差异,仅支持单人使用,存在数据丢失风险;
  • 集中化版本控制系统(CVCS):通过中央服务器存储所有版本,支持多人协同,但存在单点故障、需联网工作的问题;
  • 分布式版本控制系统(DVCS):客户端完整镜像仓库,无需联网即可工作,任意客户端可恢复服务器数据,Git 是典型代表。

Git 核心认知

(1)Git 简史

由 Linux 内核团队开发,因 BitKeeper 合作终止,基于其经验教训打造,专注高效、分布式协作。

(2)与其他版本系统的核心区别
  • 其他系统:以 "文件变更列表" 存储(记录文件增量差异),需累积差异计算最终版本,效率随增量增多下降;
  • Git:以 "快照流" 存储,每次提交保存全部文件快照,未修改文件仅保留链接,高效且直观。
(3)Git 三大状态与工作区域
  • 三大状态
    • 已修改(modified):文件已改动,未存入本地数据库;
    • 已暂存(staged):标记已修改文件,纳入下次提交快照;
    • 已提交(committed):数据安全存入本地数据库。
  • 三大工作区域
    • 工作目录(Working Directory):本地编辑文件的区域;
    • 暂存区域(Staging Area):临时存放待提交快照的区域;
    • Git 仓库(.git directory):存储所有版本数据的核心区域。
  • 核心工作流程:工作目录修改 → 暂存文件 → 提交到仓库。

Git 快速入门操作

(1)获取 Git 仓库
  • 初始化本地仓库:进入项目目录执行 git init,生成 .git 子目录;
  • 克隆远程仓库:git clone [远程仓库URL],自定义本地仓库名:git clone [URL] 自定义名称
(2)记录更新到仓库
  • 查看文件状态:git status
  • 暂存文件:git add 文件名(单个文件)、git add *(所有文件)、git add *.txt(指定类型文件);
  • 忽略文件:创建 .gitignore 文件,写入无需版本控制的文件 / 目录规则;
  • 提交更新:git commit -m "提交说明"(需先暂存),git commit -a -m "说明"(跳过暂存,直接提交已跟踪文件);
  • 移除文件:git rm 文件名(从暂存区和工作目录删除);
  • 重命名文件:git mv 原文件名 新文件名(等价于移动 + 删除原文件 + 暂存新文件)。
(3)提交消息规范
  • 标题行:一句话概括提交核心内容;
  • 主体部分:补充背景、解决的问题,换行分段,避免长句,便于日志查看。
(4)远程仓库操作
  • 关联远程仓库:git remote add origin [远程服务器URL]
  • 推送本地改动:git push origin 分支名(如 git push origin master);
  • 远程仓库重命名:git remote rename 旧名 新名
  • 移除远程仓库:git remote rm 仓库名
(5)查看提交历史
  • 基础命令:git log(按时间倒序显示提交记录);
  • 筛选记录:git log --author=用户名(查看指定用户提交)。
(6)撤销操作
  • 修正最近提交:git commit --amend(补充文件或修改提交信息);
  • 取消暂存:git reset 文件名
  • 撤销文件修改:git checkout -- 文件名(恢复到最近提交状态);
  • 丢弃本地所有改动:git fetch origin + git reset --hard origin/master(同步远程最新版本)。

Git 分支操作

(1)分支核心用途

隔离特性开发、bug 修复等工作,完成后合并到主分支,避免影响主干代码。

(2)常用分支命令
  • 创建分支:git branch 分支名
  • 切换分支:git checkout 分支名
  • 创建并切换分支:git checkout -b 分支名(等价于创建 + 切换命令);
  • 合并分支:git merge 待合并分支名(需先切换到目标分支,可能出现冲突);
  • 删除分支:git branch -d 分支名
  • 推送分支到远程:git push origin 分支名(让他人可见该分支)。
相关推荐
四维碎片4 小时前
【Qt】UDP跨平台调试工具
qt·学习·udp
好奇龙猫4 小时前
【人工智能学习-AI入试相关题目练习-第十八次】
人工智能·学习
程序员辣条4 小时前
AI产品经理:2024年职场发展的新机遇
人工智能·学习·职场和发展·产品经理·大模型学习·大模型入门·大模型教程
wanping158259923415 小时前
AI Agent(学习六-FAISS 持久化到磁盘(重启不丢记忆))
人工智能·学习·faiss
知识分享小能手5 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019数据库的操作(2)
数据库·学习·sqlserver
鄭郑5 小时前
STM32学习笔记--I2C封装与OLED(2026.2.1)
笔记·stm32·学习
酒鼎7 小时前
学习笔记(4)HTML5新特性(第3章)- WebSocket
笔记·学习·html5
-Springer-7 小时前
STM32 学习 —— 个人学习笔记2-2(新建工程)
笔记·stm32·学习
tb_first7 小时前
万字超详细苍穹外卖学习笔记4
java·spring boot·笔记·学习·spring·mybatis