JavaDriver JavaDriver
首页
  • 基础
  • 并发
  • JVM
  • 设计模式
  • 计算机网络
  • 操作系统
  • 数据结构
  • 算法
  • MYSQL
  • REDIS
  • Netty
  • Kafka
系统设计
非技术
关于
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

YoungAnn

西二旗Java老司机一枚 致力于社会主义添砖Java
首页
  • 基础
  • 并发
  • JVM
  • 设计模式
  • 计算机网络
  • 操作系统
  • 数据结构
  • 算法
  • MYSQL
  • REDIS
  • Netty
  • Kafka
系统设计
非技术
关于
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 基础

    • Java 异常有哪些类型?
    • HashMap 与 ConcurrentHashMap 的实现原理是怎样的?
    • Java 中接口和抽象类的区别
    • 为什么重写 equals 必须重写 hashcode ?
    • == 和 equals() 的区别?
    • String,StringBuffer,StringBuilder 之间有什么区别?
    • 简述 ArrayList 与 LinkedList 的底层实现以及常见操作的时间复杂度
    • 简述 BIO, NIO, AIO 的区别
      • 简述 BIO, NIO, AIO 的区别
    • 在一个静态方法内调用一个非静态成员为什么是非法的?
    • 简述 Java 的反射机制及其应用场景
    • Java 类的加载流程是怎样的?
    • 什么是双亲委派机制?
    • Java 中 sleep() 与 wait() 的区别
    • 简述 Java 中 final 关键字的作用
    • String 类能不能被继承?为什么?
    • Java 缓冲流 buffer 的用途和原理是什么?
    • 简述动态代理与静态代理
    • 阻塞队列都有哪几种,有什么区别?
    • 简述 HashSet 实现原理
  • 并发

  • JVM

  • 设计模式

  • Java相关
  • 基础
YoungAnn
2022-04-04
目录

简述 BIO, NIO, AIO 的区别

# 简述 BIO, NIO, AIO 的区别

linux中所有的外部设备都是一个文件,socket也是一个文件,有文件描述符(fd)指向它。

BIO (Blocking I/O) NIO (Non-blocking/New I/O) AIO (Asynchronous I/O)
描述 在用户进程空间调用recvfrom,直到有数据才读取数据并返回 轮训调用recvfrom,直到有数据 通知内核数据读取操作即可。用户进程不需要等待并读取数据。
图示
使用场景 活动连接数不是特别高(小于单机 1000)的情况 对于高负载、高并发的(网络)应用,应使用 NIO 的非阻塞模式来开发 我发现就目前来说 AIO 的应用还不是很广泛,Netty 之前也尝试使用过 AIO,不过又放弃了。
编辑 (opens new window)
上次更新: 2022/05/19, 21:26:01
简述 ArrayList 与 LinkedList 的底层实现以及常见操作的时间复杂度
在一个静态方法内调用一个非静态成员为什么是非法的?

← 简述 ArrayList 与 LinkedList 的底层实现以及常见操作的时间复杂度 在一个静态方法内调用一个非静态成员为什么是非法的?→

最近更新
01
电商-商品系统设计
12-17
02
关于如何写OKR
12-09
03
对事不对人 vs 对人不对事
12-09
更多文章>
Theme by Vdoing | Copyright © 2022-2023 YoungAnnn | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式