zoukankan      html  css  js  c++  java
  • 关于NIO编程

    NIO概述

    什么是NIO?

    Java NIO(New IO)是一个可以替代标准Java IO API的IO API(从Java 1.4开始),Java NIO提供了与标准IO不同的IO工作方式。

    Java NIO: Channels and Buffers(通道和缓冲区)

    标准的IO基于字节流和字符流进行操作的,而NIO是基于通道(Channel)和缓冲区(Buffer)进行操作,数据总是从通道读取到缓冲区中,或者从缓冲区写入到通道中。

    Java NIO: Non-blocking IO(非阻塞IO)

    Java NIO可以让你非阻塞的使用IO,例如:当线程从通道读取数据到缓冲区时,线程还是可以进行其他事情。当数据被写入到缓冲区时,线程可以继续处理它。从缓冲区写入通道也类似。

    Java NIO: Selectors(选择器)

    Java NIO引入了选择器的概念,选择器用于监听多个通道的事件(比如:连接打开,数据到达)。因此,单个的线程可以监听多个数据通道。

    注意:传统IT是单向。 NIO类似

    读取时候 inputStream 输入流 程序读取文件

    OutStream 输出流 程序写文件

    读写时候 是单向的

     

    有通道的概念   通道+缓冲区   而不是存放在流     类似火车

    缓冲区里面 有数据。 程序读取文件 直接通过缓冲区 取值  (缓冲区 去文件取值) 缓冲区可以复用的作用  数据都是放在缓冲区的 可以复用的

    可以多个缓冲区 封装成一个缓冲区  

    断点续传: 多线程+文件拼接    :一个文件拆分多个线程(多个请求分段下载) 最后拼接成一个文件

    区别

    IO

    NIO

    面向流

    面向缓冲区

    阻塞IO

    非阻塞IO

    选择器

    NIO 编程是 jdk1.4 在IO基础上进行(NIO中有一个非阻塞IO)、 之前的IO是阻塞的IO。阻塞IO,请求不能立即响应,IO阻塞状态,不能继续响应了,解决方案就是再开启线程(伪异步)

    NIO面向缓冲区  IO面向流

    NIO效率高,非阻塞的。Netty dubbo 之类的都用到

  • 相关阅读:
    细看运维85条军规,是否触动了你内心深处那根弦?
    SQL语句的CRUD
    sqlserver数据库类型对应Java中的数据类型
    Struts2文件上传--多文件上传(插件uploadify)
    web.xml文件详解
    关于Java的散列桶, 以及附上一个案例-重写map集合
    hibernate多表查询封装实体
    spring的7个模块
    Struts标签库详解【3】
    Struts标签库详解【2】
  • 原文地址:https://www.cnblogs.com/toov5/p/9930696.html
Copyright © 2011-2022 走看看