Java NIO 核心知识总结

2024-08-30 18:36
文章标签 java 总结 知识 核心 nio

本文主要是介绍Java NIO 核心知识总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Java NIO 核心知识总结

NIO简介

在传统的I/O模型中,是以阻塞的方式进行的也就是当一个线程执行的时候线程会一直阻塞到完成工作为止。这种模型的缺点就是在并发比较大的时候性能就会比较低,并且在每次都要给一个新的任务(连接)创建一个新的线程,这个新的线程的创建和从上一个切换到这一个线程都会都性能有影响。

为了优化这个传统的io模型,在jdk1.4新引入了一个全新的new io包,在原有代码的基础上提供了非阻塞、面向缓冲、基于通道的I/O,可以使用少量的线程处理大量的连接,提高了IO的效率和并发。

attention!

使用NIO不一定就 🟰 高性能,nio的性能优势在于高并发和高延迟的的环境。

在普通的环境中NIO不一定会比传统的io效率高。

NIO的三个核心组件

**Buffer(缓冲区):**NIO读数据的时候都是到buffer区里面进行操作的,read的时候将channel里面的数据填充到buffer里面中,写操作就是将buffer中的数据写入到channel中

**Channel(通道):**这是一个双向的,可读可写的数据传输通道,nio通过channel来实现数据的输入和输出,这个channel是一个抽象的概念。

**Selector(选择器):**允许一个线程处理多个channel,基于事件来驱动的I/O多路复用模型,所有的channel都可以注册到selector中,由selector来分配线程来处理事件。

让我来看看linux中常见的零拷贝有什么(Java只支持mmap和sendfile)

  1. mmap内存映射
  2. sendfile
  3. sendfile with DMA Scatter/Gather Day
  4. splice

好了,那么现在传统的BIO是什么,痛苦java继续复习

BIO :blocking I/O 同步阻塞模型

在这个模型中,在别处发起read后,会一直在这里阻塞,需要等到内核把数据拷贝到用户需要的地方中(用户空间)。

means

应用程序 -> (发起read请求)-> 内核(准备数据 -> buffer -> 拷贝数据)-> 返回到应用程序

当这个传统的bio模型顶不住的时候,就需要上面的nio

总结一下几个模型

同步非阻塞(NIO)

read:数据从内核空间读取到用户空间

这个模型呢,在发起read的时候是不会阻塞的,但是当到需要把数据传给用户的时候就会出现线程的阻塞,但是这个模型有一个去缺点,需要浪费性能一直去轮训是否数据已经成功传给用户了,是不是可以理解为就是把东西都工作都叠起来然后一次性干完。

多路复用模型(NIO)

现在还得插播一点linux的系统调用

select:一次查询多个系统调用的可用状态。

epoll:属于select的增强版本,优化了io的执行效率

这里就又要提到NIO的selector了,这个就是用的多路复用模型,通过selector就可以一个线程控制多个客户端的连接,减少频繁的切换的性能消耗。

在多路复用模型下,会先select调用询问内核是否准备好了,然后用户再起read请求

哦还有一个AIO,异步模型忘记了

简单的说异步模型就是基于回调机制来实现的,就是它并不会阻塞在那里,要看回调才知道有没有正常。当后台处理完成的时候,操作系统才会让线程继续干活。

真的总结了

  1. BIO:一直盲头干活,一直阻塞,直到第一批任务干完了之后才会做之后的事情。
  2. NIO:有一个监工selector,监督多个channel干活
  3. AIO:特色就是通知回调的机制

这篇关于Java NIO 核心知识总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121614

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏