IO模型简介

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

    • 前言
    • 简介
    • 正文
    • 实现
    • 总结


前言

简介

Java1.4之前的早期版本,Java对I/O的支持并不完善,开发人员在开发高性能I/O程
序的时候,会面临一些巨大的挑战和困难,主要问题如下٦。
没有数据缓冲区,I/O性能存在问题;
没有C或者C++中的Channel概念,只有输入和输出流
同步阻塞式I/O通信(BIO),通常会导致通信线程被长时间阻塞:
支持的字符集有限,硬件可移植性不好。
在Java支持异步1/0之前的很长一段时间里,高性能服务端开发领域一直被C++和C
长期占据,Java的同步阻塞I/O被大家所诟病。

正文

Linux的内核将所有外部设备都看做一个文件来操作,对一个文件的读写操作会调用
内核提供的系统命令,返回一个filedescriptor(fd,文件描述符)。而对一个socket的读
写也会有相应的描述符,称为socketfd(socket描述符),描述符就是一个数字,它指向内
核中的一个结构体(文件路径,数据区等一些属性)。

实现

根据UNIX网络编程对I/O模型的分类,UNIX提供了5种I/0模型,分别如下。
(1)阻塞I/0模型:最常用的I/0模型就是阻塞I/0模型型,缺省情形下,所有文件操
作都是阻塞的。我们以套接字接口为例来讲解此模型:不在进程空间中调用recvfrom,其系
统调用直到数据包到达且被复制到应用进程的缓冲区中或者发生错误时才返回,在此期间
一直会等待,进程在从调用recvfrom开始到它返回的整段时间内都是被阻塞的,因此被称
为阻塞I/O模型
(2)非阻塞I/O模型:recvfrom从应用层到内核的时候,如果该缓冲区没有数据的话,
就直接返回一个EWOULDBLOCK错误,一般都对非阻塞1/0模型进行轮询检查这个状态,
看内核是不是有数据到来。
图1-2非阻塞I/O模型
(3)I/O复用模型:Linux提供select/poll,进程通过将一个或多个fd传递给select或
poll系统调用,阻塞在select操作上,这样select/poll可以帮我们侦测多个fd是否处于就
绪状态。select/poll是顺序扫描fd是否就绪,而且支持的fd梦数量有限,因此它的使用受到
了一些制约。Linux还提供了一个epoll系统调用,epoll使用基于事件驱动方式代替顺序
扫描,因此性能更高。当有fd就绪时,立即回调函数rollbadck。
(4)信号驱动1/0模型:首先开启套接口信号驱动I/0功能,并退过系统调用sigaction
执行一个信号处理函数(此系统调用立即返回,进程继续仁作,它是非阻塞的)。当数据
准备就绪时,就为该进程生成一个SIGIO信号,通过信号回调通知应用程序调用recvfrom
来读取数据,并通知主循环函数处理数据。
(5)异步1/0:告知内核启动某个操作,并让内核在整个操作完成后(包括将数据从
内核复制到用户自己的缓冲区)通知我们。这种模型与信号驱动模型的主要区别是:信号
驱动1/0由内核通知我们何时可以开始一个I/0操作;异步I/O模型由内核通知我们I/O
操作何时已经完成。

总结

大家只需要有个概念,知道对于操作系统而言,底层层是支持异步I/0通信的,只不
过在很长一段时间Java并没有提供异步I/O通信的类库,导致很多原生的Java程序员对
这块儿比较陌生。当你了解了网络编程的基础知识后,理解Java的NIO类库就会更加容
易一些。

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

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

相关文章

A36 STM32_HAL库函数 之PCD通用驱动 -- B -- 所有函数的介绍及使用

A36 STM32_HAL库函数 之PCD通用驱动 -- B -- 所有函数的介绍及使用 1 该驱动函数预览1.11 HAL_PCD_SOFCallback1.12 HAL_PCD_ResetCallback1.13 HAL_PCD_SuspendCallback1.14 HAL_PCD_ResumeCallback1.15 HAL_PCD_ISOOUTIncompleteCallback1.16 HAL_PCD_ISOINIncompleteCallbac…

【财务数字化转型之底座】集团企业财务数据中台系统建设方案

引言:随着企业规模的不断扩大和业务的复杂化,传统的财务管理模式已难以满足集团企业的数据整合、分析和决策需求。因此,建设一个高效、稳定、安全的财务数据中台系统,成为集团企业数字化转型的重要一环。本方案旨在构建一个集数据…

Android SurfaceFlinger——无效化和同步信号回调(十)

上一篇文章分析了屏幕热插拔回调回调,同时通过前面文章的介绍,我们知道一共有三个比较重要的回调,这里我们看一看另外两个回调函数无效化和垂直同步的相关调用。 一、回调介绍 这两个回调从表面看都是通知屏幕刷新的,但本质上还是有区别的。 无效化回调(Invalidate Hook…

算力服务先锋!和鲸科技入选《2024中国智算产业生态图谱》

2024 年 6 月 18 日,由科智咨询发起的《2024中国智算产业生态图谱》正式发布,依托 ModelWhale 构建的智算算力资源服务,以及深耕多年的 ModelWhale 数据科学协同平台优势,和鲸科技成功入选。 “智算时代”技术不断进步&#xff0c…

Open vSwitch 内核空间的流表同步

一、内核空间的流表同步 在 Open vSwitch 的数据包转发过程中,当数据包在 Datapath 模块无法完全处理时,会通过 upcall 调用将数据包交给用户空间的 vswitchd 守护进程,由 vswitchd 守护进程生成相应的流表和行为,并发送回内核空间…

什么是空间复杂度?

空间复杂度 是指算法在计算机中执行时所需额外空间的度量,记作S(n)。这个空间包括算法在执行时所使用的所有额外存储空间,包括变量(包括静态变量和动态变量)、递归调用栈、以及输入输出数据所占据的存储空间等。其中,n…

指针并不是用来存储数据的,而是用来存储数据在内存中地址(内存操作/函数指针/指针函数)

推荐:1、4、5号书籍 1. 基本概念 首先,让小明了解指针的基本概念: 指针的定义:指针是一个变量,它存储的是另一个变量的地址。指针的声明:例如,int *p表示一个指向整数的指针变量p。 2. 形象…

生命在于学习——Python人工智能原理(2.6.1)

六 Python的文件系统 6.1 打开文件 在Python中,可以使用内置的open函数来打开文件,open函数的基本语法如下: file open(file_name, moder, buffering-1, encodingNone, errorsNone, newlineNone, closefdTrue, openerNone)参数说明&#…

【Web3】Web3.js 启动!并解决Web3 is not a constructor报错

苏泽 大家好 这里是苏泽 一个钟爱区块链技术的后端开发者 本篇专栏 ←持续记录本人自学智能合约学习笔记和经验总结 如果喜欢拜托三连支持~ 本节教大家如何启动Web3.js 目录 Web3 启动! 于是很愉快的报错 创建实例! 出来了 Web3:模块…

【Android】设置光标颜色和图标

创建主题 该主题可以更改文字下方拖拽手柄的颜色 <?xml version"1.0" encoding"utf-8"?> <resources><style name"RedTextCursor"><item name"android:colorControlActivated">#FF0000</item></…

《PIDNet: A Real-time Semantic Segmentation Network Inspired by PID Controllers》

期刊&#xff1a;CVPR 年份&#xff1a;2023 代码&#xff1a;https://github.com/XuJiacong/PIDNet 摘要 双分支网络架构已经证明了它在实时语义分割任务中的有效性和有效性。然而&#xff0c;高分辨率细节和低频上下文的直接融合的缺点是细节特征很容易被周围的上下文信息…

快储存,分布式文件系统,对象储存

Ceph块存储 镜像快照 快照可以保存某一时间点时的状态数据快照是映像在特定时间点的只读逻辑副本希望回到以前的一个状态&#xff0c;可以恢复快照使用镜像、快照综合示例 rbd create img1 --size 10G 创建镜像rbd ls 查看镜像 rbd info img1 #查看…

Win32消息机制原理及消息运转

一.消息机制原理 1.消息类型&#xff1a; WIndows定义的一系列WM_XXX开头的&#xff0c;用来表示键盘按键&#xff0c;鼠标点击&#xff0c;窗口变化&#xff0c;用户自定义等各种消息; 2.消息队列&#xff1a; Windows为每一个正在运行的程序维护一个消息队列应用程序的消…

让DroidVNC-NG支持中文输入

DroidVNC-NG支持控制端输入内容&#xff0c;但是仅支持英文字符&#xff0c;如果需要控制输入法软键盘输入中文的话就没办法了&#xff0c;经过摸索找到了解决办法。 这个解决办法有个条件就是让DroidVNC-NG成为系统级应用&#xff08;这个条件比较苛刻&#xff09;&#xff…

【Linux】性能分析器 perf 详解(三)

上一篇:【Linux】性能分析器 perf 详解(二) 1、perf kmem 1.1 简介 kmem 用于跟踪/测量内核内存属性的工具,如分配、释放、碎片率等。可以帮助开发者和系统管理员理解内核内存的分配和释放模式,从而诊断内存泄漏、过度分配等问题。 功能: 跟踪内存分配和释放:监控内…

AI的赚钱风向,彻底变了!

从2023年3月起&#xff0c;生成式AI技术的浪潮席卷全球&#xff0c;让不少人开始焦虑中国AI技术与美国的差距。然而&#xff0c;最近的趋势显示&#xff0c;AI创业的盈利模式已经发生了根本性的变化。今年&#xff0c;我们见证了AIGC&#xff08;人工智能生成内容&#xff09;企…

ExtractAItoTEXT 提取Adobe illustrator AI文件中的文字到文本文件翻译并写回到Adobe illustrator AI文件

Extract Text from Adobe illustrator to text for translate and write back to Adobe illustrator after translate in text file. Originally script from marceloliaohotmail.com during his work in SDL. Updated by me. 从Adobe illustrator中提取文本以进行翻译&#x…

【JavaScript】一键入门

目录 一、JS起源 二、JS特点 三、JS组成部分 四、JS引入方式 一、JS起源 Java Script是由网景公司的Live Script发展而来的一种运行在客户端浏览器上的脚本语言&#xff0c;可以实现网页如文本内容、数据动态变化和动画特效等即浏览器与用户交互的这种体验。 二、JS特点 …

当了面试官才知道:做好这3点,面试成功率至少提高50%

关于辉哥&#xff1a; 资深IT从业者&#xff0c; 曾就职于阿里、腾讯、美团、中信科等互联网公司和央企&#xff1b; 两岁小男孩的父亲。 不定期分享职场 | 婚姻 | 育儿 | 个人成长心得体会 关注我&#xff0c;一起学习和成长。 最近作为公司社招面…

【chatgpt】遗传编程(Genetic Programming, GP)和编译原理的相似之处

遗传编程&#xff08;Genetic Programming, GP&#xff09;和编译原理之间有一些相似之处&#xff0c;主要体现在以下几个方面&#xff1a; 语法树结构&#xff1a; GP&#xff1a;使用语法树&#xff08;Parse Trees&#xff09;来表示程序&#xff0c;其中节点代表操作符或函…