当前位置: 首页 > news >正文

Git使用手册保姆级教程

Git 使用手册

一、Git 简介与安装

  1. 什么是Git?

• Git 是一个分布式版本控制系统,用于跟踪文件变化,支持多人协作开发。

  1. 安装步骤

• Windows:通过 Git官网 下载安装包,按默认配置安装即可。

• macOS:使用 Homebrew 安装:brew install git。

• Linux:使用包管理器安装(如 apt install git 或 yum install git)。

二、基础配置

首次使用前需配置用户信息:

配置用户名(提交时显示)

git config --global user.name “你的名字”

配置邮箱(提交时显示)

git config --global user.email “你的邮箱@example.com”

查看配置信息

git config --list
三、Git 核心命令

  1. 仓库初始化与克隆

• 初始化本地仓库:
git init # 在当前目录创建.git文件夹,初始化仓库
• 克隆远程仓库:
git clone [远程仓库URL] # 例:git clone https://github.com/user/repo.git
2. 文件操作(添加、提交、状态查看)

• 查看文件状态:
git status # 查看未跟踪/已修改的文件
• 添加文件到暂存区:
git add [文件名] # 添加单个文件
git add . # 添加所有文件
• 提交暂存区文件到本地仓库:
git commit -m “提交说明(必填)”
3. 分支管理

• 查看分支:
git branch # 查看本地分支(当前分支前有*标记)
git branch -a # 查看所有分支(包括远程分支)
• 创建分支:
git branch [分支名] # 例:git branch feature/new-feature
• 切换分支:
git checkout [分支名] # 例:git checkout main
• 创建并切换分支:
git checkout -b [新分支名]
• 合并分支(在目标分支执行):
git merge [待合并分支名] # 例:git merge feature/new-feature
• 删除分支:
git branch -d [分支名] # 删除本地分支(需先切换到其他分支)
4. 远程仓库操作

• 添加远程仓库:
git remote add [别名] [远程URL] # 例:git remote add origin https://github.com/repo.git
• 查看远程仓库:
git remote -v
• 拉取远程仓库代码:
git pull [远程别名] [分支名] # 例:git pull origin main
• 推送本地代码到远程:
git push [远程别名] [分支名] # 例:git push origin main
5. 版本回退与历史查看

• 查看提交历史:
git log # 查看详细提交记录
git log --oneline # 简洁模式显示提交记录
• 回退到指定版本:
git reset --hard [commit哈希值前7位] # 例:git reset --hard a1b2c3d
• 撤销未提交的修改:
git checkout – [文件名] # 撤销文件修改,恢复到上一次提交状态
四、进阶功能

  1. 解决冲突

当合并分支出现冲突时:

  1. 打开冲突文件,会看到类似 <<<<<<< HEAD 和 >>>>>>> 标记冲突内容。

  2. 手动修改冲突部分,保留正确代码。

  3. 保存文件后,执行 git add [文件名] 和 git commit 完成合并。

  4. 标签(Tag)

• 创建标签:
git tag [标签名] # 例:git tag v1.0.0
git tag -a [标签名] -m “标签说明” # 带说明的标签
• 推送标签到远程:
git push origin [标签名] # 推送单个标签
git push --tags # 推送所有未推送的标签
3. 变基(Rebase)

• 将当前分支基于另一个分支重新应用提交:
git rebase [目标分支] # 例:git rebase main
五、实用配置与技巧

  1. 别名设置

简化常用命令:
git config --global alias.[别名] “[命令]” # 例:git config --global alias.lg “log --oneline --graph”
设置后,可通过 git lg 代替 git log --oneline --graph。

  1. .gitignore 文件

在仓库根目录创建 .gitignore 文件,用于忽略不需要跟踪的文件(如日志、编译文件等):

示例:

*.log
node_modules/
dist/
六、常见问题与解决方案

  1. 忘记提交说明怎么办?
    git commit --amend -m “新的提交说明” # 修改最后一次提交的说明
  2. 远程分支已删除,本地仍显示?
    git fetch -p # 清理无效的远程分支引用
    在这里插入图片描述

相关文章:

  • GC1267F:单相全波风扇电机预驱动芯片解析
  • ubuntu20.04安装NVIDIA显卡驱动(驱动官网下载安装包,解决开机启动黑屏问题,终极保姆式方案教程)
  • 【Android笔记】记一次 CMake 构建 Filament Android 库的完整排错过程(安卓交叉编译、CMake、Ninja)
  • King3399(ubuntu文件系统)iic(i2c)功能测试
  • IoT/基于NB28-A/BC28-CNV通信模组使用AT指令连接华为云IoTDA平台(HCIP-IoT实验2)
  • Mac 版不能连接华为 GaussDB 吗?我看 Windows 版可以连接?
  • 华为云Flexus+DeepSeek征文|华为云Flexus云服务器X实例上部署Dify:打造高效的开源大语言模型应用开发平台
  • ubuntu国内镜像源手动配置
  • RK3566 Android12 HG24C02MM/TR EEPROM适配
  • docker镜像与dockerfile
  • SpringBoot + VUE3 +deepseek实现的简单的AI对话页面(无广告,不会员)
  • 用QT写一个车速表
  • 如何在 CentOS / RHEL 上修改 MySQL 默认数据目录 ?
  • 【从零开始学习QT】Qt 概述
  • mysql prepare statement
  • Flink 状态管理深度解析:类型与后端的全面探索
  • DrissionPage:重新定义Python网页自动化,让爬虫与浏览器控制合二为一
  • Spring AI Alibaba 发布企业级 MCP 分布式部署方案
  • day12 leetcode-hot100-19(矩阵2)
  • 中山大学无人机具身导航新突破!FlightGPT:迈向通用性和可解释性的无人机视觉语言导航
  • 找企业名录的网站/关键词首页排名优化价格
  • 超级折扣2WordPress/网站为什么要seo?
  • 官方网站下载拼多多/广告推广赚钱在哪接
  • 永久免费的移动建站平台/网站快速排名公司
  • 做网站横幅用什么软件好/代引流推广公司
  • 北京网站建设求职简历/青岛网站建设有限公司