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

IO杂记I

IO 杂记一、Selector 与 select()selector.select()不会创建新线程而是让当前线程阻塞等待直到有 I/O 事件就绪。比喻一个人站在门口不来客人就不动。selector.selectNow()是非阻塞版本瞥一眼门口没人就立刻返回。Selector 底层会调用操作系统的多路复用 API如 Linux 的epoll_wait而非自己轮询。二、I/O 复用I/O Multiplexing核心思想用一个线程 一个多路复用器Selector同时监控多个通道Socket的 I/O 事件。典型步骤Selector.open()创建多路复用器。serverSocketChannel.register(selector, SelectionKey.OP_ACCEPT)注册服务端通道关注ACCEPT事件。selector.select()阻塞等待就绪事件底层调用epoll_wait/select/kqueue。遍历selectedKeys集合根据事件类型isAcceptable、isReadable、isWritable分别处理。三、三种 I/O 模型对比模型线程模型特点BIO阻塞 I/O一连接一线程read()/write()阻塞线程多连接需多线程或线程池NIOI/O 复用单线程管理成千上万连接通过 Selector 非阻塞通道轮询就绪事件AIO异步 I/O少量线程如 CPU 核心数 回调发起读写立即返回OS 完成数据拷贝后回调CompletionHandler四、零拷贝Zero-Copy1. 核心概念CPU 拷贝CPU 逐字节搬运数据占用 CPU 时间。DMA 拷贝DMA 控制器独立搬运数据不占用 CPU。2. 传统readwrite流程FileInputStreamfisnewFileInputStream(file.txt);Socketsocket...;byte[]buffernewbyte[1024];intlenfis.read(buffer);socket.getOutputStream().write(buffer,0,len);底层步骤DMA 拷贝磁盘 → 内核缓冲区PageCacheCPU 拷贝内核缓冲区 → 用户缓冲区byte[]CPU 拷贝用户缓冲区 → Socket 内核缓冲区DMA 拷贝Socket 内核缓冲区 → 网卡CPU 拷贝次数2DMA 拷贝次数2系统调用次数2readwrite上下文切换次数43.mmapwriteFileChannelfileChannelFileChannel.open(Paths.get(file.txt));MappedByteBuffermappedBufferfileChannel.map(MapMode.READ_ONLY,0,fileSize);socketChannel.write(mappedBuffer);原理mmap将磁盘文件映射到进程地址空间用户直接访问内核缓冲区省去“内核→用户”的 CPU 拷贝。步骤DMA 拷贝磁盘 → 内核缓冲区PageCacheCPU 拷贝内核缓冲区 → Socket 内核缓冲区仍有一次DMA 拷贝Socket 内核缓冲区 → 网卡CPU 拷贝次数1DMA 拷贝次数2系统调用次数2mmapwrite上下文切换次数44.sendfile基础sendfile是专门在两个文件描述符之间直接传输数据的系统调用无用户空间拷贝。流程DMA 拷贝磁盘 → 内核缓冲区CPU 拷贝内核缓冲区 → Socket 缓冲区DMA 拷贝Socket 缓冲区 → 网卡CPU 拷贝次数1DMA 拷贝次数2系统调用次数1上下文切换次数25.sendfile DMA Gather若网卡支持Scatter/Gather DMA则 CPU 无需再将数据从内核文件缓冲区复制到 Socket 缓冲区网卡直接从 PageCache 中抓取分散的数据。CPU 拷贝次数0真正的 CPU 零拷贝DMA 拷贝次数2系统调用次数1上下文切换次数26. 对比总表方式CPU 拷贝DMA 拷贝系统调用上下文切换传统 readwrite2224mmapwrite1224sendfile基础1212sendfile DMA gather copy02127. DMA Gather 详解普通 DMA只能传输连续内存块若数据分散需 CPU 先复制到连续缓冲区。DMA GatherDMA 控制器维护描述符列表地址长度直接从不连续的多个内存区域抓取数据组合后发送给设备。比喻普通 DMA快递员必须从整箱取货 → 你先将散货装进箱子CPU 拷贝DMA Gather快递员拿着清单上门自取 → 你无需动手8. Java 中的transferToFileChannel.transferTo()底层会优先使用零拷贝如 Linux 的sendfile条件不满足时优雅降级为传统拷贝。实现逻辑伪代码if(满足零拷贝条件){if(sendfile(...)0||transmitFile(...)0)returnbytes_transferred;}returntransferToViaTemporaryBuffer(src,target);// 用户态兜底内部检查源通道是否为普通本地文件目标通道是否为SocketChannel或同一文件系统上的FileChannel操作系统是否支持零拷贝系统调用局限性零拷贝失效场景目标为普通FileChannel且与源不在同一个文件系统如跨分区 C: → D:Windows 上transferTo不是真正的零拷贝数据需 SSL/TLS 加密部分平台如 macOS对FileChannel→FileChannel不支持零拷贝最佳实践分段传输单次不超过 2GB检查返回值循环传输使用 try-with-resources 关闭通道加密场景避免使用零拷贝五、零拷贝的目标总结减少/消除 CPU 拷贝减少上下文切换次数两次 DMA 拷贝磁盘→内核、内核→网卡无法避免因为它们由硬件高效完成

相关文章:

IO杂记I

IO 杂记 一、Selector 与 select() selector.select() 不会创建新线程,而是让当前线程阻塞等待,直到有 I/O 事件就绪。 比喻:一个人站在门口,不来客人就不动。selector.selectNow() 是非阻塞版本:瞥一眼门口&#xff0…...

2023B卷,书籍叠放

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:华为OD面试 文章目录 一、🍀前言 1.1 ☘️题目详情 1.2 ☘️参考解题答案 一、🍀前言 2023B卷,书籍叠放 。 1.1 ☘️题目详情 题目: 书籍的长、…...

告别混乱文件管理:用FileMeta解锁Windows隐藏的元数据超能力

告别混乱文件管理:用FileMeta解锁Windows隐藏的元数据超能力 【免费下载链接】FileMeta Enable Explorer in Vista, Windows 7 and later to see, edit and search on tags and other metadata for any file type 项目地址: https://gitcode.com/gh_mirrors/fi/Fi…...

RKNN Model Zoo实战:MobileSAM图像分割在瑞芯微平台的完整部署指南

RKNN Model Zoo实战:MobileSAM图像分割在瑞芯微平台的完整部署指南 【免费下载链接】rknn_model_zoo 项目地址: https://gitcode.com/gh_mirrors/rk/rknn_model_zoo 在边缘计算和嵌入式AI应用场景中,图像分割技术正成为智能监控、工业质检和AR/V…...

别再只用ARIMA了!用Python+statsmodels搞定SARIMA预测电商销量(附完整代码)

电商销量预测实战:用PythonSARIMA破解季节性销售波动 电商销量预测的痛点与SARIMA的破局之道 每逢大促季节,电商运营团队总会陷入两难困境:备货不足错失销售良机,库存积压又导致资金周转困难。传统ARIMA模型在预测日常销量时表现尚…...

怎样给照片去背景?2026 图片抠图方法对比|免费在线工具实测

在日常生活中,我们经常需要给照片去背景——无论是制作证件照、电商商品图、社交媒体头像,还是创意合成,去背景都是最基础的图像处理需求。但面对五花八门的工具和方法,很多人不知道如何选择。本文将从多个维度全面对比 2026 年主…...

百度网盘macOS版加速插件完全指南:三步破解限速限制

百度网盘macOS版加速插件完全指南:三步破解限速限制 【免费下载链接】BaiduNetdiskPlugin-macOS For macOS.百度网盘 破解SVIP、下载速度限制~ 项目地址: https://gitcode.com/gh_mirrors/ba/BaiduNetdiskPlugin-macOS 你是否也曾面对百度网盘macOS版那令人绝…...

OpenSTA静态时序分析工具:从入门到精通的完整指南

OpenSTA静态时序分析工具:从入门到精通的完整指南 【免费下载链接】OpenSTA OpenSTA engine 项目地址: https://gitcode.com/gh_mirrors/op/OpenSTA OpenSTA静态时序分析工具是数字集成电路设计中不可或缺的开源时序验证解决方案。作为一款功能强大的门级静态…...

带标注的胶囊缺陷识别数据集,识别率68.9%,可识别印刷不良,裂纹,戳痕,划痕,挤压变形五种缺陷,219张图,支持yolo,coco json,voc xml,文末有模型训练代码

​ 带标注的胶囊缺陷识别数据集,识别率68.9%,可识别印刷不良,裂纹,戳痕,划痕,挤压变形五种缺陷,219张图,支持yolo,coco json,voc xml,文末有模型训练代码 模…...

无王无帝定乾坤,来自田间第一人 海棠山铁哥布大道兴世

无王无帝定乾坤 ——来自田间第一人“山河起落,不在帝王;世道兴衰,系于百姓。”一、王权落幕,大道升起 古往今来,世人总把天下兴亡系于龙椅之上。 却不知—— 真正扭转乾坤的力量,深藏在乡野沃土&#xff0…...

2026年降AI工具维普检测专项实测:五款主流工具维普AIGC检测通过率完整横评

2026年降AI工具维普检测专项实测:五款主流工具维普AIGC检测通过率完整横评 拿同一篇论文,用三款工具分别处理,记录了完整检测数据。 结论先说:嘎嘎降AI(www.aigcleaner.com)效果最稳,价格也最…...

无王无帝定乾坤,来自田间第一人 立凰标定世序

谶曰 乱世去旧制,盛世出布衣。 凰标立天地,大同自此始。 一、破题:王权之外,另有乾坤 世人皆道 “普天之下,莫非王土;率土之滨,莫非王臣。” 却不知真正的变局, 起于垄亩&#xff0…...

从MySQL DBA转型ES:我的踩坑笔记与核心概念对比(Mapping/查询/索引篇)

从MySQL DBA转型ES:我的踩坑笔记与核心概念对比(Mapping/查询/索引篇) 当第一次接触Elasticsearch时,我习惯性地用MySQL的思维去理解它——结果可想而知。作为从业十年的MySQL DBA,转型过程中踩过的坑让我意识到&#…...

如何通过QuickLookVideo实现Mac视频预览效率革命:终极工具深度解析

如何通过QuickLookVideo实现Mac视频预览效率革命:终极工具深度解析 【免费下载链接】QuickLookVideo This package allows macOS Finder to display thumbnails, static QuickLook previews, cover art and metadata for most types of video files. 项目地址: ht…...

初探Taotoken模型广场如何帮助开发者快速选型与切换模型

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 初探Taotoken模型广场如何帮助开发者快速选型与切换模型 当开发者开始一个新的大模型应用项目时,面对市场上众多的模型…...

Godot-MCP终极指南:如何用AI助手5倍提升Godot游戏开发效率

Godot-MCP终极指南:如何用AI助手5倍提升Godot游戏开发效率 【免费下载链接】Godot-MCP An MCP for Godot that lets you create and edit games in the Godot game engine with tools like Claude 项目地址: https://gitcode.com/gh_mirrors/god/Godot-MCP 在…...

别死记硬背了!用Python+NumPy图解线性代数核心概念(特征值、秩、行列式)

用PythonNumPy图解线性代数:从抽象公式到可视化直觉 线性代数常被视为数据科学和机器学习的基础数学语言,但许多学习者在掌握公式计算后,依然难以理解矩阵乘法如何改变空间、特征值为何能揭示系统稳定性。本文将通过Python代码和可视化技术&a…...

深度解析fullPage.js全屏滚动插件的架构设计与性能优化策略

深度解析fullPage.js全屏滚动插件的架构设计与性能优化策略 【免费下载链接】fullPage.js fullPage plugin by Alvaro Trigo. Create full screen pages fast and simple 项目地址: https://gitcode.com/gh_mirrors/fu/fullPage.js fullPage.js作为现代Web开发中广受青睐…...

TranslucentTB完全指南:轻松实现Windows任务栏透明化的终极方案

TranslucentTB完全指南:轻松实现Windows任务栏透明化的终极方案 【免费下载链接】TranslucentTB A lightweight utility that makes the Windows taskbar translucent/transparent. 项目地址: https://gitcode.com/gh_mirrors/tr/TranslucentTB 想要让Window…...

嵌入式Linux USB Gadget ADB调试通道实现与深度解析

1. 项目概述:从零构建嵌入式设备的USB ADB调试通道在嵌入式Linux开发中,调试手段的便捷性直接决定了开发效率。传统的串口调试虽然稳定,但在传输大文件、执行复杂命令时,速度和灵活性都显得捉襟见肘。而Android Debug Bridge&…...

如何快速掌握Wallpaper Engine资源处理工具:面向初学者的完整指南

如何快速掌握Wallpaper Engine资源处理工具:面向初学者的完整指南 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg 你是否曾经遇到过想要修改Wallpaper Engine动态壁纸&a…...

Ubuntu下编译与测试libwebsockets:从x86环境验证到嵌入式移植

1. 项目概述与背景 在嵌入式开发中,尤其是涉及到网络通信模块时,我们常常会遇到一个典型的困境:直接在资源受限的目标板(比如ARM架构的开发板)上进行代码的编译、调试和功能验证,过程往往非常痛苦。编译速…...

如何免费下载中国大学MOOC视频:MoocDownloader完整使用指南

如何免费下载中国大学MOOC视频:MoocDownloader完整使用指南 【免费下载链接】MoocDownloader An MOOC downloader implemented by .NET. 一枚由 .NET 实现的 MOOC 下载器. 项目地址: https://gitcode.com/gh_mirrors/mo/MoocDownloader 你是否曾经因为网络不…...

探索Depth Anything V2:单目深度估计技术的新纪元

探索Depth Anything V2:单目深度估计技术的新纪元 【免费下载链接】Depth-Anything-V2 [NeurIPS 2024] Depth Anything V2. A More Capable Foundation Model for Monocular Depth Estimation 项目地址: https://gitcode.com/gh_mirrors/de/Depth-Anything-V2 …...

OpenPLC Editor工业自动化编程深度解析:开源PLC开发环境实战指南

OpenPLC Editor工业自动化编程深度解析:开源PLC开发环境实战指南 【免费下载链接】OpenPLC_Editor 项目地址: https://gitcode.com/gh_mirrors/ope/OpenPLC_Editor OpenPLC Editor是一款基于Beremiz项目的开源工业自动化编程工具,为工程师和开发…...

终极指南:3步解锁B站缓存视频播放自由

终极指南:3步解锁B站缓存视频播放自由 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 还在为B站缓存的m4s视频无法在其他播放器打开而…...

3步掌握Windows 11任务栏自定义神器:Taskbar11完全指南

3步掌握Windows 11任务栏自定义神器:Taskbar11完全指南 【免费下载链接】Taskbar11 Change the position and size of the Taskbar in Windows 11 项目地址: https://gitcode.com/gh_mirrors/ta/Taskbar11 还在为Windows 11僵化的任务栏设置而烦恼吗&#xf…...

拆解新客裂变与裂变率:诺云用户可直接套用的获客增长指南

在流量红利消退、公域获客成本高企的当下,“新客裂变”早已成为企业降低获客成本、实现指数级增长的核心抓手,而“裂变率”作为衡量裂变效果的核心指标,直接决定了这场获客动作的成败。今天,我们就聚焦“新客裂变”与“裂变率”这…...

软件测试从思维到实战:测试设计黄金法则与黑盒/灰盒/白盒全解析

📌为什么你的测试用例找不到Bug?你是否遇到过这样的场景:辛辛苦苦写了几十个测试用例,执行完发现一切正常,信心满满地发布上线。结果用户一用,马上就发现了严重问题。问题出在哪里?不是你的执行…...

深度解析MSPM0G3106数据手册:从80MHz Cortex-M0+内核到电机控制实战

1. 项目概述:为什么是MSPM0G3106?如果你最近在寻找一款兼具高性能、低功耗和成本效益的微控制器,用于电机控制、数字电源或者需要复杂模拟信号处理的场合,那么TI的MSPM0G系列很可能已经进入了你的视野。而其中的MSPM0G3106&#x…...