标签:NIO 数组 IO 缓冲区 New ByteBuffere 数据 字节
为什么要使用NIO?
NIO是JDK1.4加入的新包,目的是为了让java程序员可以实现高速I/O而无需编写自定义的本机代码。NIO将最耗时的I/O操作(填充和提取缓冲区)转移回操作系统,因而可以极大地提高速度。
流与块的比较
原来的I/O库与NIO最重要的区别是数据打包和传输的方式,原来的I/O以流的方式处理数据,而NIO以块的方式处理数据。
面向流的I/O一次一个字节地处理素数。一个输入流产生一个字节的数据,一个输出流消费一个字节的数据,效率相当慢。
面向块的I/O系统以块的形式处理数据。每一个操作都在一步中产生和消费一个块,效率比流快得多,但缺少一些优雅性和简单性。
缓冲区
在NIO库中,所有数据都是用缓冲区处理的。在读取数据时,它是直接读到缓冲区中的。在写入数据时,它是写入缓冲区中的。任何时候访问NIO中的数据,都是将他放到缓冲区中。
缓冲区实质上是一个数组。通常它是一个字节数组,但是也可以使用其他种类的数组,但是一个缓冲区不仅仅是数组。缓冲区提供了对数据的结构化访问,而且可以跟踪系统的读/写进程。
缓冲区类型
最常用的缓冲区类型是ByteBuffere。一个ByteBuffere可以在其底层字节数组上进行get/set操作(即自己的获取和设置)。ByteBuffere不是NIO中唯一的缓冲区类型,对于每一种基本java类型都有一种缓冲区类型:
代码
标签:NIO,数组,IO,缓冲区,New,ByteBuffere,数据,字节 来源: https://www.cnblogs.com/xingyboy/p/15968576.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。