Git仓库核心概念与工作流程详解:从入门到精通

Git仓库的基本概念

版本库(Repository)是Git的核心概念,你可以简单理解为一个被Git管理的目录。这个目录里的所有文件都能被Git跟踪,记录每次修改和删除,让你可以随时追溯历史或在未来某个时刻"还原"文件。

Git仓库的三大组成部分

  1. 远程仓库(Remote)
    远程仓库是位于服务器上的代码库,用于不同开发者之间的代码交换和更新。常见的远程仓库平台包括GitHub、GitLab和Gitee等。

  2. 本地仓库(Repository)
    本地仓库是开发者电脑上的代码库,包含远程仓库的一个完整快照,由以下三部分组成:

    • 工作区(Workspace):本地仓库根目录中除.git目录外的所有内容,存放实际文件

    • 暂存区(Stage/Index):临时保存修改的区域,信息存储在.git/index文件中

    • 版本库(.git目录):隐藏目录.git,记录所有版本控制信息

  3. 分支(Branch)
    Git默认创建主分支(master/main),分支允许你从主开发线分离出来独立工作,不影响主线开发。

 

Git工作流程详解

对于开发者来说,典型的Git工作流程包含以下6个步骤:

  1. 克隆远程仓库:将远程仓库完整复制到本地(包括代码和版本历史)

  2. 本地修改代码:基于不同开发目的创建分支并修改代码

  3. 提交到分支:将修改提交到本地分支

  4. 合并到本地主分支:将分支修改合并到本地主分支

  5. 同步远程最新代码:获取远程最新代码并与本地主分支合并(解决可能的冲突)

  6. 推送本地修改:将本地主分支推送到远程仓库

 

 

Git基础命令实战

1. 创建版本库

创建一个Git版本库非常简单。以下是在D盘testGit目录下创建仓库的步骤:

  1. 打开命令行窗口并导航到目标目录

  2. 执行git init命令初始化仓库

初始化后,目录中会生成一个隐藏的.git目录,这是Git跟踪管理版本的核心,切勿手动修改其中的文件。

2. 文件添加与提交

Git只能有效跟踪文本文件(如代码、配置文件等)的变化,对于二进制文件(如图片、视频)只能记录文件大小变化,无法追踪具体内容变更。

基本操作流程:

  1. 创建文件(如readme.txt),此时文件处于工作区

  2. 使用git add命令将文件添加到暂存区

  3. 使用git commit命令将暂存区内容提交到版本库

批量操作技巧:

  • 添加多个文件:git add file1.txt file2.txt

  • 添加所有文件:git add .

  • 从暂存区撤回:git rm --cached filename

提交修改:
使用git commit -m "提交信息"命令提交更改,提交信息应清晰描述本次修改内容。

3. 修改管理与撤销

修改文件后,Git能检测到工作区的变化:

撤销修改的两种方式:

  1. 提交修改:git add + git commit

  2. 放弃修改:git checkout -- filename(注意--后的空格)

版本回退技巧

1. 查看历史记录

使用git log查看提交历史,显示从最近到最远的提交日志:

简化显示:git log --pretty=oneline

2. 版本回退操作

回退到上一个版本:git reset --hard HEAD^
回退到上上个版本:git reset --hard HEAD^^
回退到前100个版本:git reset --hard HEAD~100

3. 撤销回退

如果回退后想恢复最新版本,可以通过版本号回退:

  1. 使用git reflog查看所有操作记录,找到目标版本号

  2. 执行git reset --hard 版本号

 

文件删除管理

在Git中删除文件有两种方式:

  1. 直接删除文件后提交:rm filename + git add + git commit

  2. 使用Git命令删除:git rm filename(直接进入暂存区)

总结

Git作为分布式版本控制系统,通过本地仓库、暂存区和版本库的三层结构,实现了高效的版本管理。掌握基本的工作流程和核心命令,能够帮助开发者在日常工作中更好地管理代码变更,提高协作效率。无论是个人项目还是团队协作,Git都是现代软件开发不可或缺的工具。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/90194.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/90194.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Web开发 05

1 React库(人话详解版)别慌,React 刚接触时是会有点懵,咱们用 “人话 类比” 一步步拆:核心概念先抓牢组件(Component)把它想成 “乐高积木”,比如做个社交 App,顶部导航…

RustDesk 自建中继服务器教程(Mac mini)

📖 教程目标 在家里的 Mac mini 上部署 RustDesk 中继服务器 (hbbs hbbr),让你从办公室、笔电或手机 低延迟、安全 地远程控制家里的 Windows 和 Mac mini。 ✅ 不依赖第三方服务器 ✅ 支持 P2P 和中继双模式 ✅ 全流量可控、跨平台 🏗️ 架…

数据库—修改某字段默认值

前言有时候,数据库的字段默认值没有正确设置,这时候需要改默认值。以下是我做的改默认值的记录,希望对网友有所帮助。1.SQL SERVER下面的示例假设你要修改名为 YourColumnName 的字段,并为其设置一个新的默认值 NewDefaultValue。…

Spring快速整合Mybatis

MyBatis是一个优秀的持久层框架&#xff0c;Spring则是广泛使用的Java应用框架。可以将两者整合可以充分发挥各自的优势。 1、Spring整合MyBatis的基本配置 添加依赖&#xff1a; <dependency><groupId>org.springframework</groupId><artifactId>spri…

基于深度学习的语音识别:从音频信号到文本转录

前言 语音识别&#xff08;Automatic Speech Recognition, ASR&#xff09;是人工智能领域中一个极具挑战性和应用前景的研究方向。它通过将语音信号转换为文本&#xff0c;为人们提供了更加自然和便捷的人机交互方式。近年来&#xff0c;深度学习技术在语音识别领域取得了显著…

本地部署Nacos开源服务平台,并简单操作实现外部访问,Windows 版本

Nacos 是一款阿里开源的动态服务发现、配置、管理平台&#xff0c;拥有易于集成、高可用与可扩展等特点。它提供了动态服务注册和发现能力&#xff0c;使得服务自动注册到服务器并且消费真能够发现提供者。本文将详细介绍如何在本地安装 Nacos &#xff0c;以及结合nat123端口映…

数据结构:反转字符串(Reversing a String)

目录 方法一&#xff1a;双指针法 方法二&#xff1a;辅助数组 方法对比总结&#xff1a; 问题定义 给定一个字符串&#xff0c;例如&#xff1a; char str[] "hello";我们的目标是把它反转成&#xff1a; "olleh"&#x1f4cc; 输入特点&#xff…

Redis Copy-on-Write机制:

Copy-on-Write机制&#xff1a; 父子进程共享内存页 当父进程修改数据时&#xff0c;内核会复制被修改的页 这可能导致内存使用量暂时增加 通俗的话描述一下可以用一个生活中的例子来通俗解释 Copy-on-Write&#xff08;写时复制&#xff09; 机制&#xff1a;&#x1f4d6; 比…

iOS加固工具有哪些?从零源码到深度混淆的全景解读

在iOS安全加固领域&#xff0c;不同项目类型对保护需求有着本质差异&#xff1a;“我有源码”与“我只有IPA”两条路径决定了你该用什么工具。本文将从 无需源码处理整个IPA包 到 源码级编译期混淆&#xff0c;分层探讨主流工具如何发挥价值&#xff0c;并附上适配方案建议。工…

Composer 可以通过指定 PHP 版本运行

是的&#xff0c;Composer 可以通过指定 PHP 版本运行&#xff0c;尤其是在服务器上有多个 PHP 版本时&#xff08;如 PHP 7.x 和 PHP 8.x&#xff09;。以下是几种常见方法&#xff1a;方法 1&#xff1a;使用 php 命令指定版本 Composer 依赖系统中的 php 命令&#xff0c;因…

vscode文件颜色,只显示自己更改的文件颜色

这个主要是因为你github git下来以后&#xff0c;用vscode打开会默认显示更改了&#xff0c;你只要在这里先手动取消更改就行了&#xff0c;注意不要把你自己更改的取消了

记录我coding印象比较深刻的BUG

4778&#xff1a;我的BUG噩梦问题描述&#xff1a;DAB播放中关ACC掉电后开ACC&#xff0c;手动切到FM/AM(有时第一次切换出现问题/有时第二次切换出现问题)&#xff0c;FM/AM不记忆关ACC前电台或者FM/AM关ACC掉电后开ACC&#xff0c;手动切到DAB再回到FM/AM&#xff0c;FM/AM不…

Kubernetes集群中Istio mTLS握手失败问题排查与解决方案

Kubernetes集群中Istio mTLS握手失败问题排查与解决方案 在微服务架构中&#xff0c;Istio 提供了基于 Envoy 的服务网格能力&#xff0c;其中 mTLS&#xff08;双向 TLS&#xff09;是确保服务间通信安全的重要机制。但在生产环境中&#xff0c;开发者常常会遇到 mTLS 握手失败…

antd+react+可输入的下拉选择组件

该组件是一个可输入的下拉选择组件&#xff0c;支持从预设选项中选择或手动输入自定义值。组件基于 React 和 Ant Design 实现&#xff0c;具有良好的交互体验和灵活的配置选项。 &#x1f9e0; 核心逻辑分析 1. 状态管理 const [isInput, setIsInput] useState(false); con…

React 面试题库

openAI React 面试题库 以下题库按模块分类&#xff08;React 架构与运行机制、核心 API、Diff 算法与事件机制、Fiber 架构与调度、并发模式与过渡、生命周期及新版生命周期对照、综合源码题、扩展专题、React 与 Vue 对比&#xff09;&#xff0c;并按难度&#xff08;初级…

查看两个tv and 手机模拟器的ip

要查看 Android 模拟器 的 IP 地址&#xff0c;你可以使用 ADB shell 命令来获取。下面是详细步骤&#xff1a;步骤 1&#xff1a;查看已连接的模拟器首先&#xff0c;确保你连接的模拟器已经启动并且连接到 ADB。你可以运行以下命令来查看已连接的设备&#xff1a;adb devices…

从零到一:用C语言构建贪吃蛇(一)- 基础框架与数据结构

资料合集下载链接: ​​https://pan.quark.cn/s/472bbdfcd014​ 第一步:绘制游戏世界 - 定义地图边界 任何游戏都需要一个舞台。在贪吃蛇中,这个舞台就是一个有明确边界的矩形地图。 1. 确定尺寸 根据笔记,我们首先要确定地图的尺寸。使用宏定义(​​#define​​)是…

AWS RDS 排查性能问题

AWS RDS 排查数据库问题 1.查看当前横在执行的SQL select id,user,time,left(info,100) from information_schema.processlist where time>0 and info is not null order by time desc ;2.AWS RDS 查看性能详情查看 Top SQL&#xff0c;AAS最高的几个sql&#xff0c;然后看这…

Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现持械检测(C#代码,UI界面版)

Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现持械检测&#xff08;C#代码&#xff0c;UI界面版&#xff09;工业相机使用YoloV8模型实现持械检测工业相机通过YoloV8模型实现持械检测的技术背景在相机SDK中获取图像转换图像的代码分析工业相机图像转换Bitmap图像格…

在 WPF 启动界面中心加载 GIF 动图

在 WPF 启动界面中心加载 GIF 动图 在 WPF 启动界面中心加载 GIF 动图可以通过多种方式实现。下面我将提供一个完整的解决方案&#xff0c;包括使用第三方库和纯 WPF 实现两种方法。 方法一&#xff1a;使用 WpfAnimatedGif 库&#xff08;推荐&#xff09; 这是最简单可靠的方…