Git基础原理和使用

Git 初识

一、版本管理痛点

在日常工作和学习中,我们经常遇到以下问题:

  • 通过不断复制文件来保存历史版本(如报告-v1、报告-最终版等)

  • 版本数量增多后无法清晰记住每个版本的修改内容

  • 项目代码管理存在同样问题

二、版本控制系统解决方案

  1. 核心功能:
  • 记录文件修改历史

  • 支持版本回溯

  • 便于多人协作

  1. 主流工具:Git

  2. 文件支持:

  • 完美支持文本文件(代码、文档等)

  • 有限支持二进制文件(图片、视频等)

三、Git 安装指南

  1. CentOS 系统:

```bash

检查是否安装

git

安装命令

sudo yum -y install git

验证安装

git --version

```

  1. Ubuntu 系统:

```bash

检查是否安装

git

安装命令

sudo apt-get install git -y

验证安装

git --version

```

四、Git 基础配置

  1. 设置用户信息:

```bash

git config --global user.name "Your Name"

git config --global user.email "email@example.com"

```

  1. 查看配置信息:

```bash

git config -l

```

  1. 删除配置:

```bash

git config --global --unset user.name

git config --global --unset user.email

```

五、核心概念解析

  1. 工作区:实际操作的目录

  2. 暂存区(Stage):临时存放改动的区域

  3. 版本库(Repository):永久存储版本信息的.git目录

六、仓库管理

  1. 创建本地仓库:

```bash

mkdir gitcode

cd gitcode

git init

```

  1. 仓库结构:
  • 生成隐藏的.git目录

  • 禁止手动修改.git内部文件

七、分支管理

  1. 分支原理:
  • 类似平行宇宙概念

  • 默认主分支:master/main

  • HEAD指针指向当前分支

  1. 分支操作:

```bash

创建分支

git branch dev

切换分支

git checkout dev

查看分支

git branch

合并分支(需先切换至主分支)

git checkout master

git merge dev

```

  1. 合并原理:
  • Fast-forward(快进式合并)

  • 保留完整版本历史记录

八、最佳实践建议

  1. 提交规范:
  • 使用有意义的提交信息

  • 保持原子性提交(每次提交一个功能/修复)

  1. 分支策略:
  • master/main分支保持稳定

  • 开发使用feature分支

  • 使用pull request进行代码审查

  1. 日常维护:
  • 定期执行git status查看状态

  • 使用.gitignore管理不需要版本控制的文件

  • 及时处理合并冲突

相关推荐
wdfk_prog13 小时前
[Linux]学习笔记系列 -- [drivers][input]input
linux·笔记·学习
盟接之桥13 小时前
盟接之桥说制造:引流品 × 利润品,全球电商平台高效产品组合策略(供讨论)
大数据·linux·服务器·网络·人工智能·制造
忆~遂愿14 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能
湘-枫叶情缘14 小时前
1990:种下那棵不落叶的树-第6集 圆明园的对话
linux·系统架构
Fcy64815 小时前
Linux下 进程(一)(冯诺依曼体系、操作系统、进程基本概念与基本操作)
linux·运维·服务器·进程
袁袁袁袁满15 小时前
Linux怎么查看最新下载的文件
linux·运维·服务器
代码游侠15 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法
Gary Studio15 小时前
rk芯片驱动编写
linux·学习
mango_mangojuice15 小时前
Linux学习笔记(make/Makefile)1.23
java·linux·前端·笔记·学习
Harvey90315 小时前
通过 Helm 部署 Nginx 应用的完整标准化步骤
linux·运维·nginx·k8s