Java-NIO(一):简介

  • Java NIO简介:

Java New IO Non Blocking IO,从java1.4版本就开始引入了新的IO API,可以替代标准的Java IO API。NIO与原来的IO有同样的作用和目的,但是使用的方式完全不同,NIO支持面向缓冲区的、基于通道的IO操作。NIO将更加高效的方式进行文件的读写操作。

  • Java NIO与IO的区别:
IO NIO
面向流(Stream Oriented) 面向缓冲区(Buffer Oriented)
阻塞IO(Blocking IO) 非阻塞IO(Non Blocking IO)
选择器(Selector)
  • 面向流和面向缓冲区:

Java NIO与IO的最大的区别就是:IO是面向流,Java NIO是面向缓冲区的。JAVA IO面向流,就意味着他在进行数据操作的时候直接是把数据流从一个方向到另外一个方向等,不需要操作缓冲区。而JAVA NIO是面向缓冲区的,每次操作数据时需要先处理数据流缓冲区,此时在操作数据流缓冲区的时候是可以对数据流进行移动操作的(Bufer允许左右移动数据流读取的位置等)。当缓冲区数据到达了一定的条件时,才开始采取数据流向。

Java IO数据流操作是单向的,而Java NIO数据操作允许数据双向的。

Java NIO

  • 阻塞IO与非阻塞IO:

  Java IO阻塞是指当一个线程在write或read操作时,该线程被阻塞,不可以做其他任何操作,直到write或read操作完成后,该线程才可以继续做其他操作。Java NIO非阻塞模式是指当一个线程通过通道(Channel)发送请求读去数据时,此时它仅可以获取目前可读的数据,如果没有可用数据,此时就什么也不获取,而不保持线程阻塞。

  非阻塞写也一样:一个线程请求写入一些数据到某通道,但不需要等待它完全写入,这个线程同时可以去做别的事情。

   线程通常将非阻塞IO的空闲时间用于在其它通道上执行IO操作,所以一个单独的线程现在可以管理多个输入和输出通道(channel)。

  • 通道与缓冲区

  Java NIO系统的核心:通道(Channel)和缓冲区(Buffer)。通道表示打开到IO设备的连接。若需要使用NIO系统,需要获取用于连接IO设备的通道以及用于容纳数据的缓冲区,然后操作缓冲区,对数据进行处理。

  通道(Channel):负责数据传输

  缓冲区(Buffer):负责数据存储

时间: 2024-08-14 08:27:27

Java-NIO(一):简介的相关文章

JAVA NIO 简介(转)

1.   基本 概念 IO 是主存和外部设备 ( 硬盘.终端和网络等 ) 拷贝数据的过程. IO 是操作系统的底层功能实现,底层通过 I/O 指令进行完成. 所有语言运行时系统提供执行 I/O 较高级别的工具. (c 的 printf scanf,java 的面向对象封装 ) 2.    Java 标准 io 回顾 Java 标准 IO 类库是 io 面向对象的一种抽象.基于本地方法的底层实现,我们无须关注底层实现.InputStream\OutputStream( 字节流 ) :一次传送一个字

JAVA NIO 简介

1.   基本     概念   IO  是主存和外部设备 (  硬盘.终端和网络等 )  拷贝数据的过程. IO  是操作系统的底层功能实现,底层通过 I/O  指令进行完成. 所有语言运行时系统提供执行 I/O  较高级别的工具. (c  的 printf scanf,java  的面向对象封装 ) 2.      Java   标准 io   回顾 Java  标准 IO  类库是 io  面向对象的一种抽象.基于本地方法的底层实现,我们无须关注底层实现. InputStream\Outp

java NIO FileChannel 学习笔记 FileChannel 简介

java NIO 中FileChannel 的实现类是  FileChannelImpl,FileChannel本身是一个抽象类. 先介绍FileChannel File Channels 是线程安全的.Channel的close方法可以随时执行(正如Channel接口所要求的).任何企图修改filechannel 对应文件大小 或者修改 filechannel position的操作都必须串行执行,第二个操作会一直阻塞直到前一个运行完.不过这些方法,具体还要看如何实现.(下文分析FileCha

java nio(non-blocking io)简介及和io

在 Java1.4之前的I/O系统中,提供的都是面向流的I/O系统,系统一次一个字节地处理数据,一个输入流产生一个字节的数据,一个输出流消费一个字节 的数据,面向流的I/O速度非常慢,而在Java 1.4中推出了NIO,这是一个面向块的I/O系统,系统以块的方式处理处理,每一个操作在一步中产生或者消费一个数据库,按块处理要比按字节处理数据快 的多. 在NIO中有几个核心对象需要掌握:缓冲区(Buffer).通道(Channel).选择器(Selector). 缓冲区Buffer 缓 冲区实际上是

Java NIO、NIO.2学习笔记

相关学习资料 http://www.molotang.com/articles/903.html http://www.ibm.com/developerworks/cn/education/java/j-nio/j-nio.html 目录 1. NIO.NIO.2简介 2. NIO中的关键技术 1. NIO.NIO.2简介 Java中的输入流.输出流都是阻塞式的输入.输出.不仅如此,传统的输入流.输出流都是通过字节的移动来处理的(即使是字符流,在底层也是通过字节流来进行处理的),也就是说,面向

Java NIO与IO的差别和比較

导读 J2SE1.4以上版本号中公布了全新的I/O类库.本文将通过一些实例来简介NIO库提供的一些新特性:非堵塞I/O,字符转换,缓冲以及通道. 一. 介绍NIO NIO包(java.nio.*)引入了四个关键的抽象数据类型,它们共同解决传统的I/O类中的一些问题. 1. Buffer:它是包括数据且用于读写的线形表结构.当中还提供了一个特殊类用于内存映射文件的I/O操作. 2. Charset:它提供Unicode字符串影射到字节序列以及逆影射的操作. 3. Channels:包括socket

Java NIO读书笔记

简介 NIO的作用就是改进程序的性能.因为有时候程序的性能瓶颈不再是CPU,而是IO.这时候NIO就派上用场了.NIO的原理就是尽量利用系统底层的资源来提高效率,比如利用DMA硬件减小CPU负荷,利用操作系统的epoll机制避免线程频繁切换.通过底层资源提高系统的吞吐量. 缓冲区 缓冲区就是一个固定大小的一组数据.缓冲区有四个非常重要的属性:容量,限制,位置,标记.容量就是一个缓冲区最大能容量的元素数量,限制就是对容量进行逻辑上的限制,位置用于跟踪get或者put方法的位置,标记用于reset函

java NIO-Channel

基本简介 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

java进阶 ------ Java NIO

Java NIO I/O简介 I/O或者输入输出指的是计算机与外部世界或者一个程序与计算机的其余部分之间的接口.它对于任何计算机系统都非常关键,因而所有I/O的主体实际上是内置在操作系统中的.单独的程序一般是让系统为它们完成大部分的工作. 在Java编程中,直到最近一直使用流的方式完成I/O.所有I/O都被视为单个的字节的移动,通过一个称为Stream的对象一次移动一个字节.流I/O用于与外部世界接触.它也在内部使用,用于将对象转换为字节,然后再转换回对象. NIO与原来的I/O有同样的作用和目

Java NIO与IO的区别和比较

传统的socket IO中,需要为每个连接创建一个线程,当并发的连接数量非常巨大时,线程所占用的栈内存和CPU线程切换的开销将非常巨大.使用NIO,不再需要为每个线程创建单独的线程,可以用一个含有限数量线程的线程池,甚至一个线程来为任意数量的连接服务.由于线程数量小于连接数量,所以每个线程进行IO操作时就不能阻塞,如果阻塞的话,有些连接就得不到处理,NIO提供了这种非阻塞的能力. 小量的线程如何同时为大量连接服务呢,答案就是就绪选择.这就好比到餐厅吃饭,每来一桌客人,都有一个服务员专门为你服务,