自己学习的一点总结,大家多多指教:
flip()
使缓冲区为一系列新的通道写入或相对获取 操作做好准备:它将限制设置为当前位置,然后将位置设置为 0。
一段简单的代码,可以更好的理解:
package xubin.test;
import java.io.IOException;
import java.nio.ByteBuffer;
public class TestNio {
private static final int size = 1024;
public static void view(ByteBuffer buffer){
System.out.println("Capacity: "+buffer.capacity()
+", Limit: "+buffer.limit()
+", Posotion: "+buffer.position());
}
public static void viewContent(ByteBuffer buffer){
while(buffer.hasRemaining()){
System.out.print((char)buffer.get());
}
System.out.println();
}
public static void main(String[] args) throws IOException {
ByteBuffer buffer = ByteBuffer.allocate(size);
buffer.put("java_nio".getBytes());
view(buffer);
buffer.flip();
view(buffer);
viewContent(buffer);
}
}
输出:
Capacity: 1024, Limit: 1024, Posotion: 8
Capacity: 1024, Limit: 8, Posotion: 0
java_nio
总之呢,在你对buffer 塞了东西之后,在你要对其进行读写操作之前,调用该方法做好准备~
rewind()
使缓冲区为重新读取已包含的数据做好准备:它使限制保持不变,将位置设置为 0。
接上面的代码:
buffer.rewind();
view(buffer);
buffer.put("java_io".getBytes());
view(buffer);
输出:
Capacity: 1024, Limit: 8, Posotion: 0
Capacity: 1024, Limit: 8, Posotion: 7
放少了没事,如果放个"java_nio_nio",那就要报BufferOverflowException
clear()
使缓冲区为一系列新的通道读取或相对放置 操作做好准备:它将限制设置为容量大小,将位置设置为 0。
继续接上面的代码:
buffer.clear();
view(buffer);
buffer.put("java_nio_java_nio".getBytes());
buffer.flip();
viewContent(buffer);
输出:
Capacity: 1024, Limit: 1024, Posotion: 0
java_nio_java_nio
clear()就是初始化一下,限制变为容量限制,初始位置就为0,现在就是随便放啥都可以了;
mark() & reset()
mark( ) 就是把当前的Position( ) 设置一个标记!
reset( ) 就是将此缓冲区的位置重置为以前标记的位置。
上面那些flip(), rewind(), clear() 都会在调用时把mark() 给扔了!
接上面代码:
buffer.position(2);
view(buffer);
buffer.mark();
buffer.position(4);
view(buffer);
buffer.reset();
view(buffer);
输出:
Capacity: 1024, Limit: 17, Posotion: 2
Capacity: 1024, Limit: 17, Posotion: 4
Capacity: 1024, Limit: 17, Posotion: 2
是不是很弱智 , 不过很好理解了~~
相关推荐
缓冲区提供了四种基本操作:clear、flip、rewind和reset。 * clear():将缓冲区设置为准备好进行读取或写入操作,将限制设置为容量大小,将位置设置为0。 * flip():将缓冲区设置为准备好进行写入操作,将限制设置...
Java NIO(New Input/Output)是Java提供的一种新的输入输出处理机制,它与传统IO基于流的处理方式不同,NIO支持面向缓冲区的(Buffer-oriented)、基于通道的(Channel-based)I/O操作。在Java NIO中,Buffer类是...
### Java NIO 学习笔记 #### 一、概述 Java NIO (Non-Blocking IO,也称为 Java New IO),是 Java 对传统 IO 模型的一次重大改进,旨在提高程序处理大量并发连接的能力。NIO 的核心组件包括 Channels、Buffers 和 ...
Buffer提供了诸如clear、flip、rewind和mark等方法,用于管理和操作缓冲区中的数据。 2. **通道(Channel)**:通道类似于流,但它是双向的,可以进行读写操作。Java.nio.channels包中定义了多种类型的通道,如...
Java性能优化中,NIO(New Input/Output)框架是一个重要的技术,它的引入极大地提升了Java在处理I/O操作时的效率。NIO的核心组件包括Buffer(缓冲区)和Channel(通道),它们共同解决了传统I/O模型中的一些性能...
### Java NIO 学习 #### 一、Java NIO 的背景及意义 在Java早期版本(JDK 1.4之前),IO操作主要依赖于`java.io`包中的流式(stream-based)API,这类API是阻塞式的。虽然对于大多数日常应用场景而言,这种模型...
Java中的缓冲区是处理大量数据时的关键工具之一。通过合理地使用直接缓冲区和非直接缓冲区,开发者可以显著提高应用程序的性能。了解缓冲区的基本概念、特性和使用方法对于任何Java开发者来说都是非常重要的。
Buffer的操作主要包括:`put()`用于写入数据,`get()`用于读取数据,`clear()`和`flip()`用于重新配置缓冲区状态,`rewind()`将位置设为0,`hasRemaining()`检查是否有剩余数据,以及`mark()`和`reset()`进行标记和...