【深度学习-目标检测】05 - YOLOv1 论文学习与总结

论文地址:You Only Look Once:Unified, Real-Time Object Detection

论文学习

在这里插入图片描述

1. 摘要

  1. YOLO的提出:作者提出了YOLO,这是一种新的目标检测方法。与传统的目标检测方法不同,YOLO将目标检测视为一个回归问题,直接从图像像素到边界框坐标和类别概率的映射。
  2. 方法特点
    • 统一的架构:YOLO使用单一的神经网络直接从完整图像中预测边界框和类别概率。这种统一的架构使得YOLO在检测性能上可以进行端到端的优化。
    • 实时性能:YOLO极其快速。基础的YOLO模型可以实时处理图像,每秒处理45帧。而更小的版本,Fast YOLO,可以处理高达155帧每秒,同时仍保持较高的平均精度(mAP)。
  3. 性能比较
    • 与其他实时检测系统相比,YOLO在本地化错误方面表现更好,但在背景误判方面的表现较差。
    • YOLO在从自然图像到其他领域(如艺术作品)的泛化能力方面优于其他检测方法,如DPM和R-CNN。

补充:YOLO将目标检测视为回归问题的理解

想象一下,你有一张包含多个物体的照片,比如一张客厅的照片,里面有沙发、电视和一只猫。现在,如果我们要用一个计算机程序来识别这张照片中的物体及其位置,这就是一个典型的目标检测问题。

  1. 在传统的目标检测方法中,这个过程通常分为两步:
    • 定位:首先识别出照片中可能有物体的区域(比如沙发的位置、电视的位置和猫的位置)。
    • 分类:然后对这些区域进行分类,判断它们是什么物体(比如这是沙发、那是电视、还有一只猫)。
  2. 而在YOLO这种使用回归方法的目标检测中,这个过程被简化为一步:
    • 程序一次性直接从照片中“预测”出每个物体的位置(用边界框坐标表示)和类别(用类别概率表示)。这里的“预测”就是回归问题中的输出。
    • 具体来说,对于照片中的每个物体(比如猫),YOLO会输出:
      • 边界框坐标:这是一组连续的数值,描述了猫在照片中的确切位置。通常包括猫所在区域的左上角和右下角的坐标。
      • 类别概率:这是一组数值,表示这个区域是猫的概率有多高,以及它可能是其他类别(如沙发、电视)的概率。

所以,YOLO通过一次计算就能告诉我们:“在这个位置有一只猫,我有90%的把握它是猫,10%的可能是其他东西。” 这就是回归问题在YOLO中的应用。

一般来说,YOLO会预测五个值(中心x坐标,中心y坐标,宽度,高度,类别概率)。

2. 引言

  1. 人类视觉系统的效率:作者首先指出,人类能够迅速且准确地通过视觉系统识别图像中的物体、它们的位置以及它们之间的相互作用。这种能力使我们能够轻松地执行复杂任务,例如驾驶汽车。

  2. 计算机视觉的挑战:作者强调,如果能开发出快速且准确的目标检测算法,那么计算机将能够在没有特殊传感器的情况下驾驶汽车,为残疾人提供实时场景信息,甚至实现通用的、响应灵敏的机器人系统。

  3. 现有目标检测系统的局限性

    • 传统的目标检测系统通常将分类器重新用于检测。这些系统通过在测试图像中的不同位置和尺度上评估分类器来检测物体。
    • 例如,形变部件模型(DPM)使用滑动窗口方法,而最近的方法如区域卷积神经网络(R-CNN)使用区域提议方法来首先生成潜在的边界框,然后在这些提议的框上运行分类器。
    • 这些复杂的流程不仅速度慢,而且难以优化,因为每个组件都需要单独训练。
  4. YOLO的提出:鉴于现有方法的这些局限性,作者提出了YOLO,这是一种全新的目标检测方法。 YOLO将目标检测视为一个单一的回归问题,直接从图像像素到边界框坐标和类别概率的映射。

3. 统一检测

  1. 目标检测的统一化

    • YOLO方法将目标检测的多个组成部分统一到一个单一的神经网络中。这种统一化的方法使得从整个图像中直接预测边界框和类别概率成为可能。
    • 与传统的、由多个阶段组成的目标检测方法不同,YOLO的统一网络同时处理多个任务,包括特征提取、边界框预测和类别概率预测。
  2. 网络结构
    在这里插入图片描述

    • YOLO网络将输入图像划分为一个S×S的网格。如果某个物体的中心落在一个网格单元内,那么这个网格单元就负责检测该物体。
    • 每个网格单元预测B个边界框和这些框的置信度(confidence scores)。置信度反映了模型对框中包含物体的把握,以及预测框与实际框的匹配程度。
    • 每个边界框包含5个预测值:中心点的x和y坐标、宽度、高度和置信度。
    • 每个网格单元还预测C个条件类别概率,这些概率是在网格单元包含物体的条件下计算的。
      在这里插入图片描述
  3. 训练和优化

    • YOLO网络在整个图像上进行训练,直接优化检测性能,而不是像传统方法那样分别训练不同的组件。
    • 网络使用大量的真实图像进行训练,学习如何准确地预测物体的位置和类别。
  4. 实时性能

    • 由于YOLO将检测过程简化为单一网络的前向传递,因此它能够以非常快的速度运行,实现实时目标检测。
    • YOLO的这种快速性能使其适用于需要实时反馈的应用,如自动驾驶汽车和机器人导航。

4. 训练

  1. 预训练卷积层
    • YOLO首先在ImageNet 1000类竞赛数据集上预训练其卷积层。这一步骤旨在让网络学习到丰富的特征表示,这些特征对于后续的目标检测任务至关重要。
    • 预训练使用的是网络的前20个卷积层,后接平均池化层和全连接层。
  2. 转换为检测模型
    • 在预训练完成后,模型被转换为目标检测模型。这包括在网络中添加额外的卷积层和全连接层,这些层的权重是随机初始化的。
    • 为了适应目标检测任务,输入图像的分辨率被提高到448×448。
  3. 损失函数
    • YOLO使用平方和误差作为其损失函数。这个选择简化了优化过程,但并不完全符合目标检测的最终目标,即最大化平均精度。
    • 损失函数对不同类型的误差(如定位误差、分类误差)进行加权,以处理不同重要性的误差。
  4. 训练细节
    • 在训练过程中,使用了多种技术来提高模型的泛化能力和减少过拟合。这包括dropout和数据增强(如随机缩放和平移图像,调整图像的曝光和饱和度)。
    • 训练使用不同的学习率安排,初始阶段使用较低的学习率,随后逐渐提高。
  5. 边界框预测的特殊处理
    • YOLO对边界框的宽度和高度预测使用平方根变换,以更好地处理不同大小的边界框。
    • 训练时,只有与真实边界框重叠最多的预测框被认为是“负责”该目标的,这有助于模型学习到更准确的边界框。

5. 推理

  1. 单次网络评估
    • 在推理(即目标检测)阶段,YOLO只需要对测试图像进行一次网络评估。这与传统的目标检测方法不同,后者可能需要多次评估来检测图像中的不同区域。
    • 这种单次评估方法使得YOLO能够快速处理图像,实现实时目标检测。
  2. 网格设计和空间约束
    • YOLO将输入图像划分为S×S的网格,并在每个网格单元内进行预测。这种设计强制实现了预测的空间多样性,即每个网格单元负责检测位于其内部的目标。
    • 这种方法有助于减少重复检测和提高检测的准确性。
  3. 边界框和类别预测
    • 对于每个网格单元,YOLO预测多个边界框和这些框的置信度,以及条件类别概率。
    • 置信度反映了模型对框中包含物体的把握,以及预测框与实际框的匹配程度。条件类别概率则表示在检测到物体的情况下,它属于各个类别的概率。
  4. 非极大值抑制
    • YOLO使用非极大值抑制(Non-maximal Suppression,NMS)来处理多个重叠的边界框。这一步骤有助于去除冗余的检测结果,确保每个物体只被检测一次。
    • NMS通过保留置信度最高的边界框,并去除与其重叠度较高的其他边界框来实现。
  5. 实时性能
    • 由于YOLO的简单和高效,它能够在保持较高检测精度的同时,实现实时的处理速度。这使得YOLO适用于需要快速响应的应用场景,如视频监控、自动驾驶等。

6. YOLO的局限性

  1. 空间约束的影响
    • 由于YOLO将图像划分为S×S的网格,并且每个网格单元负责预测边界框,这种设计带来了空间约束。每个网格单元只能预测有限数量的边界框(通常是两个),并且只能预测一个类别。
    • 这种空间约束限制了YOLO在处理图像中靠近或重叠的多个小物体时的效果。
  2. 对小物体的检测挑战
    • YOLO在检测小物体,特别是当这些小物体以群组形式出现时,表现不如大物体。这部分是因为小物体可能在网格划分中不够显著,或者被网格中的大物体所掩盖。
  3. 泛化能力的局限
    • YOLO在处理不常见的物体或不寻常的物体排列时可能会遇到困难。由于YOLO在训练过程中学习到的特征和物体的空间关系,如果遇到新的或罕见的物体排列,它可能无法准确地进行检测。
  4. 定位误差
    • YOLO在定位物体时可能不够精确,尤其是对于小物体。这可能是由于YOLO在设计上对速度的优先考虑,牺牲了一些定位精度。
  5. 损失函数的不完美
    • YOLO使用的平方和误差损失函数可能不完全适合目标检测任务。这种损失函数可能导致对不同类型的误差(如定位误差和分类误差)的不平衡处理。

7. 与其他检测系统的比较

  1. 与形变部件模型(DPM)的比较
    • DPM使用滑动窗口方法进行目标检测,它通过多个阶段来提取特征、分类区域、预测边界框等。 与DPM相比,YOLO使用单一的卷积神经网络来同时完成这些任务,提高了速度和准确性。
  2. 与区域卷积神经网络(R-CNN)的比较
    • R-CNN及其变体(如Fast R-CNN和Faster R-CNN)使用区域提议方法来定位目标,然后对这些区域进行分类。与这些方法相比,YOLO的速度更快,因为它不需要为每个区域单独运行分类器。
  3. 其他快速检测器的比较
    • 一些研究致力于加速DPM和R-CNN等传统检测方法。尽管这些方法在速度上有所提升,但它们通常仍然无法达到实时性能。
    • YOLO的设计初衷是速度,因此它在保持较高准确度的同时实现了实时性能。
  4. 检测性能的比较
    • YOLO在PASCAL VOC等标准数据集上与其他检测系统进行了性能比较。YOLO在实时性能方面表现出色,同时在准确性方面也与其他先进系统相当。
  5. 错误类型的比较
    • YOLO与其他系统在错误类型上有所不同。例如,与Fast R-CNN相比,YOLO在定位错误上表现更差,但在背景误判方面表现更好。
  6. 泛化能力的比较
    • YOLO在从自然图像到其他领域(如艺术作品)的泛化能力方面优于其他检测方法。这表明YOLO学习到的特征表示具有较好的泛化性。

8. 实验

  1. PASCAL VOC 2007实验
    • YOLO在PASCAL VOC 2007数据集上进行了测试,这是一个广泛使用的目标检测基准数据集。
    • 实验结果显示,YOLO在实时性能方面表现出色,同时在平均精度(mAP)方面也取得了竞争性的结果。
  2. 与Fast R-CNN的比较和错误分析
    • 作者对YOLO和Fast R-CNN在VOC 2007数据集上的表现进行了详细比较,并分析了两种方法的错误类型。
    • YOLO在定位错误上表现较差,但在背景误判方面表现更好。
  3. 结合YOLO和Fast R-CNN
    • 作者探索了将YOLO和Fast R-CNN结合使用的可能性,以减少Fast R-CNN的背景误判。
    • 结合使用两种方法可以提高整体检测性能。
  4. PASCAL VOC 2012实验
    • YOLO也在PASCAL VOC 2012数据集上进行了测试,以进一步验证其性能。
    • 尽管YOLO在某些类别上的表现不如其他方法,但在整体性能上仍然具有竞争力。
  5. 泛化能力测试
    • 为了测试YOLO的泛化能力,作者在艺术品数据集上进行了实验,这些数据集包括风格迥异的图像。
    • YOLO在这些数据集上的表现证明了其对不同领域图像的良好泛化能力。
  6. 实时性能测试
    • YOLO的实时性能在实验中得到了验证,特别是在处理视频流和实时应用场景时。

9. 结论

  1. YOLO的创新性
    • 作者强调了YOLO作为一个统一的目标检测模型的创新性。与传统的基于分类器的方法不同,YOLO直接从图像像素到边界框坐标和类别概率的映射,实现了目标检测的简化。
  2. 端到端训练
    • YOLO的整个模型可以进行端到端的训练,这意味着从输入图像到最终的检测结果,整个过程在一个统一的网络结构中完成,没有分离的组件或阶段。
  3. 实时性能
    • YOLO的一个显著特点是其实时性能。作者指出,YOLO是目前文献中最快的通用目标检测方法,适用于需要快速响应的应用,如视频监控和机器人导航。
  4. 泛化能力
    • YOLO不仅在标准的目标检测数据集上表现出色,而且在泛化到新领域(如艺术品检测)时也显示出强大的能力。
  5. 未来工作方向
    • 尽管YOLO在多个方面表现出色,但作者也承认它在某些情况下(如检测小物体或群体中的物体)的局限性。这为未来的改进和研究提供了方向。
  6. 对计算机视觉领域的贡献
    • 作者总结说,YOLO的提出对于推动实时目标检测技术的发展具有重要意义,为计算机视觉领域提供了一个高效、准确的工具。

这篇论文《You Only Look Once:Unified, Real-Time Object Detection》的主要创新点和贡献可以总结如下:

  1. 统一的检测框架
    • YOLO将目标检测的过程简化为一个单一的神经网络,这与传统的目标检测方法(通常涉及多个阶段,如候选区域生成和分类)形成鲜明对比。这种统一的框架简化了目标检测流程,提高了效率。
  2. 实时目标检测
    • YOLO能够实现实时目标检测,这对于需要快速响应的应用(如自动驾驶、视频监控)至关重要。它能够以极高的帧率处理图像,同时保持较高的检测精度。
  3. 端到端训练
    • YOLO可以进行端到端的训练,意味着从输入图像到最终的检测结果,整个过程在一个统一的网络结构中完成。这种训练方式使得模型能够更好地优化整体检测性能。
  4. 直接回归到边界框和类别概率
    • YOLO直接从图像像素回归到边界框坐标和类别概率,这种方法避免了传统目标检测方法中的复杂区域提议和后续分类步骤。
  5. 泛化能力
    • YOLO在不同的数据集和应用场景中表现出良好的泛化能力,能够有效地从自然图像泛化到其他领域,如艺术品检测。
  6. 减少背景误判
    • 与其他目标检测方法相比,YOLO在减少背景误判方面表现更为出色,这对于减少错误检测非常重要。
  7. 空间约束的引入
    • 通过将图像划分为网格,并在每个网格单元中进行预测,YOLO引入了空间约束,这有助于提高检测的准确性。

YOLO

在这里插入图片描述

  1. 图像预处理
    • 输入图像首先被调整到固定的大小(例如448×448像素),以适应YOLO网络的输入要求。
  2. 划分网格
    • 调整后的图像被划分为S×S的网格(例如7×7)。每个网格单元负责检测落在其内部的目标。
  3. 特征提取
    • 图像通过卷积神经网络(CNN)进行前向传播。网络包含多个卷积层、池化层和全连接层,用于提取图像的特征。
  4. 边界框预测
    • 每个网格单元预测B个边界框。每个边界框包含5个参数:中心点的x和y坐标、宽度、高度和置信度。置信度表示预测框中是否存在目标,以及预测框的准确性。
  5. 类别概率预测
    • 每个网格单元还预测C个条件类别概率。这些概率表示在该单元中检测到目标的情况下,目标属于每个类别的概率。
  6. 组合预测
    • 对于每个边界框,其最终的类别置信度由边界框的置信度和条件类别概率相乘得到。这表示了边界框包含特定类别的目标的概率。
  7. 非极大值抑制
    • 由于多个网格单元可能预测重叠的边界框,YOLO应用非极大值抑制(NMS)来去除重复的检测。在NMS中,保留置信度最高的边界框,并移除与其重叠度较高的其他边界框。
  8. 最终检测输出
    • 经过NMS处理后,YOLO输出最终的检测结果,包括每个检测到的目标的位置(边界框)和类别。

补充:关于在网格内预测目标

YOLO的工作流程中,会将原始图像划分为S*S个网格,然后在每个网格中去预测每个预测框和类别,关于这句话的理解,需要详细解释一下:

首先,划分为S*S个网格,每个网格属于一个”责任区域“,并不是”预测区域“,所谓”责任区域“指的是:如果某个物体的中心点落在某个网格内,那么对于这个物体的边界框预测和类别预测将是由这个网格负责,它可以在整个图像上完成预测工作,并不局限于自己的这个网格区域。

因此,如果存在某个物体跨越了多个网格,也是没有问题的,因为这个物体的中心点一定是在某个网格内的,它的预测任务将是由这个网格负责。

以上内容旨在记录自己的学习过程以及复习,如有错误,欢迎批评指正,谢谢阅读。

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

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

相关文章

Django 访问前端页面一直在转异常:ReferenceError:axios is not defined

访问&#xff1a;http://127.0.0.1:8080/ my.html 一、异常&#xff1a; 二、原因 提示&#xff1a;axios找不到&#xff01;&#xff01; 查看代码<script src"https://unpkg.com/axios/dist/axios.min.js"></script>无法访问到官网 三、解决 Using j…

HTML转Word后打开默认为WEB板式改为页面视图

在html 标签后面添加 <html xmlns:vurn:schemas-microsoft-com:vmlxmlns:ourn:schemas-microsoft-com:office:officexmlns:wurn:schemas-microsoft-com:office:wordxmlns:mhttp://schemas.microsoft.com/office/2004/12/ommlxmlnshttp://www.w3.org/TR/REC-html40> 在…

模型量化之AWQ和GPTQ

什么是模型量化 模型量化&#xff08;Model Quantization&#xff09;是一种通过减少模型参数表示的位数来降低模型计算和存储开销的技术。一般来说&#xff0c;模型参数在深度学习模型中以浮点数&#xff08;例如32位浮点数&#xff09;的形式存储&#xff0c;而模型量化可以…

【R语言爬虫】使用rvest包爬取豆瓣读书Top 250,仅需50行代码(速度挺快)

【R语言爬虫】使用rvest包爬取豆瓣读书Top 250&#xff0c;仅需50行代码&#xff08;速度挺快&#xff09; 爬取目标 书名&#xff0c;作者&#xff0c;出版社&#xff0c;时间&#xff0c;价格 https://book.douban.com/top250?start0 发现需要爬取的内容就在<div cla…

Xshell连接不上本地虚拟机中的linux处理

0、连接不上虚拟机的原因 1、本地电脑未启用VMware网络。 2、连接协议选择错误。 3、防火墙屏蔽IP。 4、虚拟机网络连接模式不是桥接模式。 1、查看本地是否启用VMware的网络 2、连接协议选择 我们在新建会话时&#xff0c;可选的协议有FTP和SFTP两种&#xff0c;其中FTP采用21…

软件测试题常见版

1、python深浅拷贝 浅拷贝&#xff0c;指的是重新分配一块内存&#xff0c;创建一个新的对象&#xff0c;但里面的元素是原对象中各个子对象的引用。深拷贝&#xff0c;是指重新分配一块内存&#xff0c;创建一个新的对象&#xff0c;并且将原对象中的元素&#xff0c;以递归的…

高效资源分配:用CRM系统打造更优销售策略

CRM系统在销售团队中有着重要的应用&#xff0c;但很多销售人员可能对CRM系统存在一些负面的看法&#xff0c;认为它只是一种监管工具&#xff0c;操作空间单调枯燥。那么&#xff0c;如何让销售团队爱上CRM系统呢&#xff1f; 下面我们将分享几个方法&#xff0c;帮助销售经理…

Spring Boot国际化i18n配置指南

Spring Boot国际化i18n配置指南 一、配置 1、yml文件配置 spring:messages:basename: i18n/Messages,i18n/Messages_en_US,i18n/Messages_zh_CNencoding: UTF-8i18n&#xff1a;表示国际化文件的父目录 Messages&#xff1a;默认国际化文件 Messages_en_US&#xff1a;英文文…

关于MybatisPlus自动转化驼峰命名规则配置mapUnderscoreToCamelCase的个人测试和总结

关于MybatisPlus自动转化驼峰命名规则配置mapUnderscoreToCamelCase的个人测试和总结 测试一&#xff1a;没有添加 自动转化的配置&#xff0c;且domain中的属性名称和数据库的字段名称一致测试二&#xff1a;没有添加自动转化配置i&#xff0c;domain属性名userPassword和数据…

装饰模式(单一责任)

Decorator&#xff08;装饰模式&#xff1a;单一责任模式&#xff09; 链接&#xff1a;装饰模式实例代码 解析 目的 在某些情况下我们可能会“过度地使用继承来扩展对象的功能”&#xff0c;由于继承为类型引入的静态特质&#xff0c;使得这种扩展方式缺乏灵活性&#xff…

<JavaEE> TCP 的通信机制(三) -- 滑动窗口

目录 TCP的通信机制的核心特性 四、滑动窗口 1&#xff09;什么是滑动窗口&#xff1f; 2&#xff09;滑动窗口的作用是什么&#xff1f; 3&#xff09;批量传输出现丢包如何处理&#xff1f; 1> 接收端ACK丢包 2> 发送端数据包丢包 4&#xff09;适用性 TCP的通…

为什么深度学习神经网络可以学习任何东西

下图你所看到的&#xff0c;是著名的曼德尔布罗特集&#xff0c;我们可以见证这个集合呈现出的复杂形态&#xff1a; 要理解神经网络如何学习曼德尔布罗特集&#xff0c;我们首先需要从最基础的数学概念讲起&#xff1a;什么是函数&#xff1f;函数本质上是一个将输入转化为输出…

机器学习---adaboost二分类、回归

1. adaboost二分类 import numpy as np import matplotlib.pyplot as pltfrom sklearn.ensemble import AdaBoostClassifier from sklearn.tree import DecisionTreeClassifier from sklearn.datasets import make_gaussian_quantiles# 几个关键参数有n_samples&#xff08;生…

基于JSP+Servlet+Mysql的宠物管理系统(简单增删改查)

基于JSPServletMysql的宠物管理系统_简单增删改查 一、系统介绍二、功能展示1.主页2.增加3.修改4.查询5.删除 四、其它1.其他系统实现五.获取源码 一、系统介绍 项目名称&#xff1a;基于JSPServletMysql的宠物管理系统(简单增删改查) 项目架构&#xff1a;B/S架构 开发语言…

FonePaw iOS Transfer for Mac: 让您的IOS设备数据无忧传输

在数字世界里&#xff0c;随着我们的生活与科技越来越紧密&#xff0c;数据传输成为了我们日常生活中的重要部分。尤其对于广大的苹果用户来说&#xff0c;如何方便、快速地传输数据成为了他们关注的焦点。今天&#xff0c;我要为大家介绍一款专门为Mac用户设计的IOS数据传输工…

60.0/PhotoShop制作简单的网页效果

目录 60.1 网页的页面元素 60.1.1 网页的概念 60.2网站设计的步骤 60.2.1草案 ​编辑 60.2.2 丰富内容 60.2.3 利用切片划分功能区域 60.3.0 Gif动画的制作 60.1 网页的页面元素 60.1.1 网页的概念 是指通过浏览器能访问到的 Web 页面&#xff0c;是一种超文本文件&am…

SpringBoot3 核心原理

1. 事件和监听器 1. 生命周期监听 场景&#xff1a;监听应用的生命周期 1. 监听器-SpringApplicationRunListener 自定义SpringApplicationRunListener来监听事件&#xff1b; 编写SpringApplicationRunListener 实现类在 META-INF/spring.factories 中配置 org.springfram…

同城配送小程序解决方案

前言 同城配送小程序解决方案。 一、用户用车 用户打开小程序后发货地址自动定位到用户当前位置&#xff0c;用户可通过地址后的>号在地图上选择新的发货地址和卸货地址&#xff0c;小程序会自动规划出行线路&#xff0c;计算距离和运费价格。 用户仅用简单操作后就可以…

冒泡排序(C语言)

void BubbleSort(int arr[], int len) {int i, j, temp;for (i 0; i < len; i){for (j len - 1; j > i; j--){if (arr[j] > arr[j 1]){temp arr[j];arr[j] arr[j 1];arr[j 1] temp;}}} } 优化&#xff1a; 设置标志位flag&#xff0c;如果发生了交换flag设置…

C++ 文件操作篇

C 文件操作篇 文章目录 C 文件操作篇1 简介1.1 继承关系1.2 流1.3 缓冲区输入输出流中的缓冲streambuf 2 文件操作步骤2.1 头文件2.2 创建流对象2.3 打开文件2.4 读取数据第一种&#xff1a;**按元素直接读**第二种&#xff1a;**使用getline按行读**第三种&#xff1a;**使用*…