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 分支名(让他人可见该分支)。
相关推荐
babe小鑫11 小时前
大专经济信息管理专业学习数据分析的必要性
学习·数据挖掘·数据分析
winfreedoms12 小时前
ROS2知识大白话
笔记·学习·ros2
在这habit之下12 小时前
Linux Virtual Server(LVS)学习总结
linux·学习·lvs
我想我不够好。12 小时前
2026.2.25监控学习
学习
im_AMBER12 小时前
Leetcode 127 删除有序数组中的重复项 | 删除有序数组中的重复项 II
数据结构·学习·算法·leetcode
CodeJourney_J12 小时前
从“Hello World“ 开始 C++
c语言·c++·学习
匠心网络科技12 小时前
JavaScript进阶-ES6 带来的高效编程新体验
开发语言·前端·javascript·学习·面试
2501_9181269113 小时前
stm32死锁是怎么实现的
stm32·单片机·嵌入式硬件·学习·个人开发
盐焗西兰花13 小时前
鸿蒙学习实战之路-STG系列(5/11)-守护策略管理-添加与修改策略
服务器·学习·harmonyos
你怎么知道我是队长14 小时前
前端学习---HTML---块元素和行内元素
前端·学习·html