`
hz_chenwenbiao
  • 浏览: 1010764 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

java nio之 clear(),flip(),rewind(),reset(),mark()方法的学习(转)

阅读更多

自己学习的一点总结,大家多多指教:

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

 

是不是很弱智 , 不过很好理解了~~

分享到:
评论
4 楼 yueyue73 2013-12-03  
写得尊好
3 楼 lujingjs 2012-07-18  
写的很不错,学习了
2 楼 barrytdc 2012-02-18  
赞一个,简单易懂,非常好。
1 楼 cnlinkin 2010-07-11  
不错~

相关推荐

    JavaNIO.pdf

    缓冲区提供了四种基本操作:clear、flip、rewind和reset。 * clear():将缓冲区设置为准备好进行读取或写入操作,将限制设置为容量大小,将位置设置为0。 * flip():将缓冲区设置为准备好进行写入操作,将限制设置...

    Java NIO 主要类和方法(Java NIO中文版 附录C)

    Java NIO(New Input/Output)是Java提供的一种新的输入输出处理机制,它与传统IO基于流的处理方式不同,NIO支持面向缓冲区的(Buffer-oriented)、基于通道的(Channel-based)I/O操作。在Java NIO中,Buffer类是...

    javaNIO学习笔记

    ### Java NIO 学习笔记 #### 一、概述 Java NIO (Non-Blocking IO,也称为 Java New IO),是 Java 对传统 IO 模型的一次重大改进,旨在提高程序处理大量并发连接的能力。NIO 的核心组件包括 Channels、Buffers 和 ...

    Java_NIO_API详解[参照].pdf

    Buffer提供了诸如clear、flip、rewind和mark等方法,用于管理和操作缓冲区中的数据。 2. **通道(Channel)**:通道类似于流,但它是双向的,可以进行读写操作。Java.nio.channels包中定义了多种类型的通道,如...

    Java性能优化之使用NIO提升性能(Buffer和Channel)

    Java性能优化中,NIO(New Input/Output)框架是一个重要的技术,它的引入极大地提升了Java在处理I/O操作时的效率。NIO的核心组件包括Buffer(缓冲区)和Channel(通道),它们共同解决了传统I/O模型中的一些性能...

    java NOI 学习

    ### Java NIO 学习 #### 一、Java NIO 的背景及意义 在Java早期版本(JDK 1.4之前),IO操作主要依赖于`java.io`包中的流式(stream-based)API,这类API是阻塞式的。虽然对于大多数日常应用场景而言,这种模型...

    Java中的缓冲区(直接缓冲区、非直接缓冲区等).docx

    Java中的缓冲区是处理大量数据时的关键工具之一。通过合理地使用直接缓冲区和非直接缓冲区,开发者可以显著提高应用程序的性能。了解缓冲区的基本概念、特性和使用方法对于任何Java开发者来说都是非常重要的。

    NIO初体验 ╥﹏╥

    Buffer的操作主要包括:`put()`用于写入数据,`get()`用于读取数据,`clear()`和`flip()`用于重新配置缓冲区状态,`rewind()`将位置设为0,`hasRemaining()`检查是否有剩余数据,以及`mark()`和`reset()`进行标记和...

Global site tag (gtag.js) - Google Analytics