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整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Python包管理工具核心指令uvx举例详细解析

《Python包管理工具核心指令uvx举例详细解析》:本文主要介绍Python包管理工具核心指令uvx的相关资料,uvx是uv工具链中用于临时运行Python命令行工具的高效执行器,依托Rust实... 目录一、uvx 的定位与核心功能二、uvx 的典型应用场景三、uvx 与传统工具对比四、uvx 的技术实

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c