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 分支名(让他人可见该分支)。
相关推荐
想搞艺术的程序员20 小时前
Java Survivor区学习笔记
java·笔记·学习·垃圾回收
吃杠碰小鸡20 小时前
学习英语的思路性问题
学习
-Springer-20 小时前
STM32 学习 —— 个人学习笔记9-2(USART串口数据包 & 串口收发 HEX 及 文本 数据包)
笔记·stm32·学习
会编程的李较瘦21 小时前
【C语言程序设计学习】一、C语法基础
c语言·开发语言·学习
困死,根本不会21 小时前
【C 语言】指针学习笔记:从底层原理到实战应用
c语言·开发语言·笔记·学习·算法
努力努力再努力...21 小时前
学习Multipath多路径
学习
小郝 小郝1 天前
51 与32 单片机LED控制详解
c语言·开发语言·经验分享·学习·51单片机
金山几座1 天前
C#学习记录-类(Class)
开发语言·学习·c#
red_redemption1 天前
自由学习记录(132)
学习
非凡ghost1 天前
Zen Browser:基于 Firefox 的极简开源浏览器,隐私与速度兼得
前端·网络·windows·学习·开源·firefox·软件需求