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

相关文章

Kubernetes常用命令大全近期总结

《Kubernetes常用命令大全近期总结》Kubernetes是用于大规模部署和管理这些容器的开源软件-在希腊语中,这个词还有“舵手”或“飞行员”的意思,使用Kubernetes(有时被称为“... 目录前言Kubernetes 的工作原理为什么要使用 Kubernetes?Kubernetes常用命令总

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

Java访问修饰符public、private、protected及默认访问权限详解

《Java访问修饰符public、private、protected及默认访问权限详解》:本文主要介绍Java访问修饰符public、private、protected及默认访问权限的相关资料,每... 目录前言1. public 访问修饰符特点:示例:适用场景:2. private 访问修饰符特点:示例:

详解Java如何向http/https接口发出请求

《详解Java如何向http/https接口发出请求》这篇文章主要为大家详细介绍了Java如何实现向http/https接口发出请求,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用Java发送web请求所用到的包都在java.net下,在具体使用时可以用如下代码,你可以把它封装成一

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu