Git 版本控制:基础介绍与常用操作

目录

Git 的基本概念

Git 安装与配置

Git 常用命令与操作

1. 初始化本地仓库

2. 版本控制工作流程

3. 分支管理

4. 解决冲突

5. 回退和撤销

6. 查看提交日志


前言

在软件开发过程中,开发者常常需要在现有程序的基础上进行修改和扩展。但如果不加以管理,很容易出现以下两种问题:

  1. 担心修改错误:怕修改了代码后,原始文件也被弄坏。
  2. 版本混乱:每次修改后,我们都需要保存一个副本,但随着修改的增多,版本数量也随之增加,如何管理这些版本成了难题。

为了解决这些问题,版本控制工具应运而生。Git 是其中最流行的一个,它能帮助我们高效地管理代码版本,确保项目开发过程中的每一步都可追溯、可恢复。

Git 的基本概念

Git 是一个分布式版本控制系统,用于跟踪文件的变化,尤其是在多人协作开发时显得尤为重要。它提供了一个清晰的工作流程,能够让每个人都保持同步并避免冲突。

1. Git 的工作区和仓库

Git 的工作区域包含以下几个部分:

  • 工作区 (Working Directory):即你本地的代码文件夹,开发者在这里进行编码。
  • 暂存区 (Staging Area):你已经修改并准备提交的文件。通过 git add 命令可以把文件加入暂存区。
  • 本地仓库 (Local Repository):本地保存的版本库,提交的内容存储在这里。
  • 远程仓库 (Remote Repository):如 GitHub、GitLab 等托管代码的服务器,团队成员可以从中拉取(pull)或推送(push)代码。

Git 安装与配置

  1. 下载 Git
    前往 Git 官网下载安装包,根据操作系统选择对应版本。 Git 官网https://git-scm.com/downloadshttps://git-scm.com/downloadshttps://git-scm.com/downloads

  2. 安装 Git
    安装过程有较多的配置项,界面如何勾选请参考这篇博客,如下:

       。。。未完成。。

  1. 配置 Git 用户信息
    安装后,需要配置 Git 的全局用户名和邮箱,确保每次提交记录时能够标记出具体的用户。

    git config --global user.name "Your Name"
    git config --global user.email "email@example.com"
    
  2. 配置 SSH 密钥
    为了方便与远程仓库(如 GitHub、GitLab 等)进行交互,我们需要配置 SSH 密钥。

    ssh-keygen -t rsa
    # 按提示生成 SSH 密钥
    cat ~/.ssh/id_rsa.pub
    # 将生成的公钥复制到远程仓库的 SSH 密钥配置中
    

Git 常用命令与操作

1. 初始化本地仓库

git init  # 初始化一个空的 Git 仓库

2. 版本控制工作流程

  • 将文件添加到暂存区:

    git add .  # 添加当前目录下所有文件
    git add fileName  # 添加某个指定文件
    
  • 提交修改到本地仓库:

    git commit -m "提交备注"
    
  • 查看状态:

    git status  # 查看当前仓库的状态
    
  • 推送本地修改到远程仓库:

    git push  # 推送到远程仓库
    
  • 拉取远程仓库的修改:

    git pull  # 拉取远程仓库最新的修改
    

3. 分支管理

Git 允许我们在不同的分支上进行开发,分支操作使得多个开发者可以并行工作,而不会互相影响。

  • 查看本地分支:

    git branch  # 查看所有本地分支
    
  • 创建并切换到新分支:

    git checkout -b new-branch  # 创建并切换到新分支
    
  • 切换到已存在的分支:

    git checkout existing-branch  # 切换到指定的分支
    
  • 合并分支:

    git checkout master  # 切换到 master 分支
    git merge new-branch  # 合并新分支到 master
    
  • 删除分支:

    git branch -d branch-name  # 删除本地分支
    git push origin --delete branch-name  # 删除远程分支
    

4. 解决冲突

出现CONFLICT => 表明该文件有冲突,被至少2人修改。

解决方法:

  • 查看日志,去线下和对应修改人员沟通,确定如何修改。
  • 切忌在协作开发时,随意修改或者删除他人代码

下面为大家演示一个冲突解决案例:

① 现在我们在新建一个分支,dev1

git checkout -b dev1

② 查看:

$ git branchdev
* dev1master

③ 我们在div1分支下,对文件里边的内容进行修改

④ 然后上传:

git add .
git commit -m"div1进行提交"
git checkout master
git merge dev1
git push

⑤ 上传成功之后,我们在切换到dev分支之下,我们可以看到 div 分支下的文件内容 已经和dev1分支下的文件中的内容不一致了,现在我们重写一个新的内容

⑥ 同样进行上传,然后当我们在合并分支的时候会出现CONFLACT冲突,如下图:

⑦ 打开我们的文件,可以看到git自动帮我们标记出了具体的冲突内容:

⑧ 产生冲突后,我们必须手动解决冲突,只需要我们保留我们想要的结果

⑨ 更改完错误以后需要我们commit提交,然后上传

造成冲突的原图:

在不同分支之下,更改了相同的文件

5. 回退和撤销

  • 撤销未提交的修改

    git checkout fileName  # 撤销某个文件的修改
    git checkout .  # 撤销所有文件的修改
    
  • 回退到上一个提交:

    git reset --hard HEAD^  # 回退到上一个版本
    

6. 查看提交日志

  • 查看提交历史

    git log  # 查看详细的提交日志
    git log --oneline  # 简洁格式查看提交历史
    
  • 查看命令历史

    git reflog  # 查看 Git 命令历史
    

总结

        Git 是一个强大的版本控制工具,它能够帮助开发者高效地管理代码版本,追踪代码修改,避免版本冲突,并且支持多人协作开发。掌握 Git 的基本操作和工作流程对于现代软件开发至关重要。如果你刚刚开始接触 Git,建议多练习命令行操作,理解每一个命令的意义,逐步建立起版本控制的思维方式。

希望本文能帮助你更好地理解 Git,并使用它进行版本管理和团队协作。

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

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

相关文章

Java 大视界 -- Java 大数据在量子通信安全中的应用探索(69)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

国产碳化硅(SiC)MOSFET模块在电镀电源中全面取代进口IGBT模块

国产碳化硅(SiC)MOSFET模块在电镀电源中全面取代进口IGBT模块,倾佳电子杨茜分析以下几方面的技术、经济和政策优势: 倾佳电子杨茜致力于推动SiC碳化硅模块在电力电子应用中全面取代IGBT模块,助力电力电子行业自主可控…

linux用户管理

创建用户:useradd (创建用户命令的详细使用:如何创建用户-CSDN博客) (如何创建具有重复uid的用户:如何创建具有重复uid的用户-CSDN博客) 删除用户:userdel (删除用户命…

【C++动态规划 离散化】1626. 无矛盾的最佳球队|2027

本文涉及知识点 C动态规划 离散化 LeetCode1626. 无矛盾的最佳球队 假设你是球队的经理。对于即将到来的锦标赛,你想组合一支总体得分最高的球队。球队的得分是球队中所有球员的分数 总和 。 然而,球队中的矛盾会限制球员的发挥,所以必须选…

【安全测试】测开方向学习遇到的问题记录

【问题一】springboot如何访问静态资源文件 springboot启动根路径位置 F:\untitled05\demo4\src\main\resources\static 例如图片位置存放在F:\untitled05\demo4\src\main\resources\static即可 配置文件配置 spring.web.resources.static-locationsfile:/F:/untitled05/de…

Github 2025-01-25Rust开源项目日报Top10

根据Github Trendings的统计,今日(2025-01-25统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Rust项目10Python项目1Vue项目1JavaScript项目1Deno: 现代JavaScript和TypeScript运行时 创建周期:2118 天开发语言:Rust, JavaScript协议类型…

详细解释java当中的所有知识点(前言及数据类型及变量)(第一部分)

会将java当中的所有的知识点以及相关的题目进行分享,这是其中的第一部分,用红色字体标注出重点,以及加粗的方式进行提醒 目录 一、Java语言概述 1.Java语言简介 2.语言优势 二、main方法 1.Java程序结构组成 2.运行Java程序 3.注释 4.…

HarmonyOS应用开发快速入门

本节内容将帮助开发者学习如何构建一个全新的HarmonyOS应用,学习使用DevEco Studio创建新项目、使用预览器预览页面、了解基础组件如Image、Text等。 文章目录 一、介绍二、创建一个新项目三、页面结构总览四、自定义文本视图五、创建Image组件 一、介绍 根据本教程…

ICSE‘25 LLM Assistance for Memory Safety

不知道从什么时候开始,各大技术社区,技术群聊流行着 “用Rust重写!” ,放一张图(笑死… 这不, 随着大模型技术的流行,大家都在探索如何让大模型自动完成仓库级别(全程序)的代码重构,代码变换(Refactor&…

Java实现.env文件读取敏感数据

文章目录 1.common-env-starter模块1.目录结构2.DotenvEnvironmentPostProcessor.java 在${xxx}解析之前执行,提前读取配置3.EnvProperties.java 这里的path只是为了代码提示4.EnvAutoConfiguration.java Env模块自动配置类5.spring.factories 自动配置和注册Enviro…

基于Python的人工智能患者风险评估预测模型构建与应用研究(下)

3.3 模型选择与训练 3.3.1 常见预测模型介绍 在构建患者风险评估模型时,选择合适的预测模型至关重要。不同的模型具有各自的优缺点和适用场景,需要根据医疗数据的特点、风险评估的目标以及计算资源等因素进行综合考虑。以下详细介绍几种常见的预测模型。 逻辑回归(Logisti…

零基础Vue入门4——Vue3基础核心

本节重点: vue3最佳实践 ref reactive computed watch、watchEffect 讲解重点之后下面会带大家开发一个页面(表单表格),之后会有一个TodoList的小练习,文末附有小练习的代码参考。跟着练习一定带你可以上手开发vu…

一文掌握ADB的安装及使用

文章目录 一、什么是ADB?二、 安装ADB2.1 下载ADB2.2 配置环境变量 三、连接Android设备四、 常用ADB命令五、ADB高级功能5.1 屏幕截图和录制5.2 模拟按键输入5.3 文件管理5.4 系统设置管理5.5 系统操作指令5.6 日志操作指令5.7 APK操作指令5.8 设备重启和恢复 六、…

使用Edu邮箱申请一年免费的.me域名

所需材料:公立Edu教育邮箱一枚(P.S:该服务不支持所有的Edu教育邮箱,仅支持比较知名的院校) 说到域名,.me这个后缀可谓是个性十足,适合个人网站、博客等。.me是黑山的国家顶级域名(c…

7.抽象工厂(Abstract Factory)

抽象工厂与工厂方法极其类似,都是绕开new的,但是有些许不同。 动机 在软件系统中,经常面临着“一系列相互依赖的对象”的创建工作;同时,由于需求的变化,往往存在更多系列对象的创建工作。 假设案例 假设…

Visual Studio使用GitHub Copilot提高.NET开发工作效率

GitHub Copilot介绍 GitHub Copilot 是一款 AI 编码助手,可帮助你更快、更省力地编写代码,从而将更多精力集中在问题解决和协作上。 GitHub Copilot Free包含哪些功能? 每月 2000 代码补全,帮助开发者快速完成代码编写。 每月 …

[JavaWeb]搜索表单区域

一.注意事项 设置外边距:margin:(参数可省去部分)上 下 左 右 二.源代码 <!DOCTYPE html> <html lang"zh-CN"> <head> <meta charset"UTF-8"> <title>Tlias智能学习辅助系统</title> <style> /* 导航栏样…

NLP自然语言处理通识

目录 ELMO 一、ELMo的核心设计理念 1. 静态词向量的局限性 2. 动态上下文嵌入的核心思想 3. 层次化特征提取 二、ELMo的模型结构与技术逻辑 1. 双向语言模型&#xff08;BiLM&#xff09; 2. 多层LSTM的层次化表示 三、ELMo的运行过程 1. 预训练阶段 2. 下游任务微调 四、ELMo的…

Eureka 服务注册和服务发现的使用

1. 父子工程的搭建 首先创建一个 Maven 项目&#xff0c;删除 src &#xff0c;只保留 pom.xml 然后来进行 pom.xml 的相关配置 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xs…

OpenCV:二值化与自适应阈值

目录 简述 1. 什么是二值化 2. 二值化接口 2.1 参数说明​​​​​ 2.2 示例代码 2.3 运行结果 3. 自适应阈值 3.1 参数说明 3.2 示例代码 3.3 运行结果 4. 总结 4.1 二值化 4.2 自适应阈值 相关阅读 OpenCV&#xff1a;图像的腐蚀与膨胀-CSDN博客 简述 图像二值…