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 分支名(让他人可见该分支)。
相关推荐
&&Citrus2 小时前
【CPN学习笔记(二)】Chap2 非分层颜色 Petri 网——从一个简单协议开始读懂 CPN
笔记·学习·php·cpn·petri网
小橘子8314 小时前
(学习)Claude Code 源码架构深度解析
学习·程序人生·架构
diablobaal5 小时前
云计算学习100天-第102天-Azure入门4
学习·云计算·azure
AI_零食6 小时前
Flutter 框架跨平台鸿蒙开发 - 自定义式按钮设计应用
学习·flutter·ui·华为·harmonyos·鸿蒙
小陈phd6 小时前
多模态大模型学习笔记(三十)—— 基于YOLO26 Pose实现车牌检测
笔记·学习
野指针YZZ6 小时前
XV6操作系统:trap机制学习笔记
笔记·学习
diygwcom7 小时前
学习开源数据采集与监视控制SCADA-即工业组态开源框架FUXA
学习·开源
zl_dfq7 小时前
Python学习5 之【字符串】
python·学习
ada0_ada18 小时前
qt模块学习记录
开发语言·qt·学习
Xudde.8 小时前
班级作业笔记报告0x10
笔记·学习·安全·web安全·php