标记、位置、限制和容量值遵守以下不变式:
0 <= 标记 <= 位置 <= 限制 <= 容量
|
位置 |
限制 |
容量 |
标记 |
|
position |
limit |
capcity |
mark |
mark |
/ |
/ |
/ |
position |
reset |
position |
/ |
/ |
/ |
clear |
0 |
capcity |
/ |
丢弃 |
flip |
0 |
position |
/ |
/ |
rewind |
0 |
/ |
/ |
/ |
缓冲区的容量 是它所包含的元素的数量。缓冲区的容量不能为负并且不能更改。
缓冲区的限制 是第一个不应该读取或写入的元素的索引。缓冲区的限制不能为负,并且不能大于其容量。
缓冲区的位置 是下一个要读取或写入的元素的索引。缓冲区的位置不能为负,并且不能大于其限制。
(这部分是转载)
http://book.51cto.com/art/200902/109721.htm
表 5.4:在Buffer上创建不同透视的方法
方法
|
Capacity
|
新缓冲区的初始值
|
Position
|
Limit
|
Mark
|
ByteBuffer duplicate()
|
capacity
|
position
|
limit
|
mark
|
ByteBuffer slice()
|
remaining()
|
0
|
remaining()
|
未定义
|
ByteBuffer asReadOnlyBuffer()
|
capacity
|
position
|
limit
|
mark
|
CharBuffer asCharBuffer()
|
remaining()/2
|
0
|
remaining()/2
|
未定义
|
DoubleBuffer asDoubleBuffer()
|
remaining()/8
|
0
|
remaining()/8
|
未定义
|
FloatBuffer asFloatBuffer()
|
remaining()/4
|
0
|
remaining()/4
|
未定义
|
IntBuffer asIntBuffer()
|
remaining()/4
|
0
|
remaining()/4
|
未定义
|
LongBuffer asLongBuffer()
|
remaining()/8
|
0
|
remaining()/8
|
未定义
|
ShortBuffer asShortBuffer()
|
remaining()/2
|
0
|
remaining()/2
|
未
|
分享到:
相关推荐
Java NIO系列教程(三) Buffer Java NIO系列教程(四) Scatter/Gather Java NIO系列教程(五) 通道之间的数据传输 Java NIO系列教程(六) Selector Java NIO系列教程(七) FileChannel Java NIO系列教程(八) ...
java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java...
01-Java NIO-课程简介.mp4 05-Java NIO-Channel-FileChannel详解(一).mp4 06-Java NIO-Channel-FileChannel详解(二).mp4 08-Java NIO-Channel-ServerSocketChannel.mp4 09-Java NIO-Channel-SocketChannel.mp4 ...
标准的IO基于字节流和字符流进行操作的,而NIO是基于通道(Channel)和缓冲区(Buffer)进行操作,数据总是从通道读取到缓冲区中,或者从缓冲区写入到通道中。 Java NIO: Non-blocking IO(非阻塞IO) Java NIO...
java NIO是 java New IO 的简称,在 jdk1.4 里提供的新 api 。 Sun 官方标榜的特性如下: – 为所有的原始类型提供 (Buffer) 缓存支持。 – 字符集编码解码解决方案。 – Channel :一个新的原始 I/O 抽象。 – 支持...
Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据...
Java NIO英文高清原版
讲解了 JavaIO 与 JAVA NIO区别,JAVA NIO设计理念,以及JDK中java NIO中语法的使用
主要介绍了Java NIO Buffer过程详解,缓冲区在java nio中负责数据的存储。缓冲区就是数组。用于存储不同数据类型的数据。,需要的朋友可以参考下
Java NIO 深入探讨了 1.4 版的 I/O 新特性,并告诉您如何使用这些特性来极大地提升您所写的 Java 代码的执行效率。这本小册子就程序员所面临的有代表性的 I/O 问题作了详尽阐述,并讲解了 如何才能充分利用新的 I/O ...
java nio 实现socketjava nio 实现socketjava nio 实现socketjava nio 实现socketjava nio 实现socket
01-Java NIO-课程简介.mp4 02-Java NIO-概述.mp4 03-Java NIO-Channel-概述.mp4 04-Java NIO-Channel-FileChannel(介绍和示例).mp4 05-Java NIO-Channel-FileChannel详解(一).mp4 06-Java NIO-Channel-FileChannel...
java侧起server(NioUdpServer1.java),基于Java Nio的selector 阻塞等候,一个android app(NioUdpClient1文件夹)和一个java程序(UI.java)作为两个client分别向该server发数据,server收到后分别打印收到的消息...
java NIO.zip
java基于NIO实现Reactor模型源码java基于NIO实现Reactor模型源码java基于NIO实现Reactor模型源码java基于NIO实现Reactor模型源码java基于NIO实现Reactor模型源码java基于NIO实现Reactor模型源码java基于NIO实现...
java NIO技巧及原理解析,java IO原理,NIO框架分析,性能比较
java nio 读文件,java nio 读文件
JAVA NIO学习资料JAVA NIO学习资料
Many serious Java programmers, especially enterprise Java programmers, consider the new I/O API--called NIO for New Input/Output--the most important feature in the 1.4 version of the Java 2 Standard ...
本类,是专门为了处理大文件,按行读取开发... fbb.rewind(); fbb.clear(); if(this.fc.read(fbb)==-1){ EOF=true; return 0;}else{ fbb.flip(); return fbb.limit(); } } 把 fbb.position() 改成 fbb.limit()