缓冲器(Buffer)的细节

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/caiwenfeng_for_23/article/details/8454223

 

 从上面继承图层来看,了解Buffer很重要。

 

Buffer=数据+四个索引

 

正是四个索引才是的数据可以高效访问,这四个索引是:mark(标记),position(位置),limit(界限),capacity(容量)。

 

不变式

标记、位置、限制和容量值遵守以下不变式:

0 <= 标记 <= 位置 <= 限制 <= 容量

 

 

以下是设置和复位索引以及查询的方法:

                             capacity() :返回此缓冲区的容量。

                                  clear() :清除此缓冲区。

                                     flip() :反转此缓冲区。

                                    limit() :返回此缓冲区的限制。

                   limit(int newLimit) :设置此缓冲区的限制。

                                   mark() :在此缓冲区的位置设置标记。

                               position() :返回此缓冲区的位置。 
         position(int newPosition) :设置此缓冲区的位置。 
                            remaining() :返回当前位置与限制之间的元素数。 
                                   reset() :将此缓冲区的位置重置为以前标记的位置。
                                 rewind() :重绕此缓冲区。

通过代码查看:

package org.com.mayi;

import java.nio.ByteBuffer;
import java.nio.CharBuffer;

public class Test_ByteBuffer {
	static int capacity1,limit1,position1;
	/**
	 * @param args
	 */
	public static void main(String[] args){
		byte[] b = "my test".getBytes();//获取字节数组
		ByteBuffer bytebuffer =ByteBuffer.allocate(15);//定义一个buffer,并为之分配容量。
		bytebuffer.put(b);//把字节放进buffer
		
		  capacity1 = bytebuffer.capacity();//返回buffer容量
		  limit1 = bytebuffer.limit();//返回buffer界限
		  position1 = bytebuffer.position();//返回buffer位置
		  /*没有设置mark(标记), */
		 System.out.println("容量:"+capacity1+"    界限:"+limit1+"   位置: "+position1+"    mark:"+"需要自己设置");
		 
		//反转此缓冲区,从结果来看,我们知道,capacity不变,limit=position  ;position=0;
	     //此时的buffer感觉就像队列一样,先进先出。
		 bytebuffer.flip();
		 capacity1 = bytebuffer.capacity();
		  limit1 = bytebuffer.limit();
		  position1 = bytebuffer.position();
		 System.out.println("容量:"+capacity1+"    界限:"+limit1+"   位置: "+position1+"    mark:"+"需要自己设置");
		 
		 //重绕此缓冲区,其实就是相当于刷新一下,通知buffer做好读或写的准备,并没有什么改变。
		 bytebuffer.rewind();
		 capacity1 = bytebuffer.capacity();
		  limit1 = bytebuffer.limit();
		  position1 = bytebuffer.position();
		 System.out.println("容量:"+capacity1+"    界限:"+limit1+"   位置: "+position1+"    mark:"+"需要自己设置");

	}

}


 

输出:

容量:15    界限:15   位置: 7    mark:需要自己设置
容量:15    界限:7   位置: 0    mark:需要自己设置
容量:15    界限:7   位置: 0    mark:需要自己设置


 

 通过查看API文档,又找到一些官方解释:哈哈。。。

清除、反转和重绕

除了访问位置、限制、容量值的方法以及做标记和重置的方法外,此类还定义了以下可对缓冲区进行的操作:

  • clear() 使缓冲区为一系列新的通道读取或相对放置 操作做好准备:它将限制设置为容量大小,将位置设置为 0。

  • flip() 使缓冲区为一系列新的通道写入或相对获取 操作做好准备:它将限制设置为当前位置,然后将位置设置为 0。

  • rewind() 使缓冲区为重新读取已包含的数据做好准备:它使限制保持不变,将位置设置为 0。

 

理解了这四个索引的工作是很重要的,做到数据输入输出时,缓冲区在干什么,心中有数,不至于茫茫然,看别人的代码这样写,你也稀里糊涂的跟着写了。

如果有兴趣,可以查看《java编程思想》的NIO那一章,有很详细的解释,里面是图文结合,比我的好多了。我在这里写下,也只是做一个简单笔记罢了。。。

展开阅读全文

没有更多推荐了,返回首页