知识大全 读写缓冲区中的数据
Posted 知
篇首语:闲散如酸醋,会软化精神的钙质;勤奋像火炬,能燃起智慧的火焰。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 读写缓冲区中的数据相关的知识,希望对你有一定的参考价值。
对于缓冲区来说 最重要的操作就是读写操作 缓冲区提供了两种方法来读写缓冲区中的数据 get put方法和array方法 而get put方法可以有三种读写数据的方式 按顺序读写单个数据 在指定位置读写单个数据和读写数据块 除了上述的几种读写数据的方法外 CharBuffer类还提供了用于专门写字符串的put和append方法 在本文及后面的文章中将分别介绍这些读写缓冲区的方法 虽然使用allocate方法创建的缓冲区并不是一次性地分配内存空间 但我们可以从用户地角度将一个缓冲区想象成一个长度为capacity的数组 当缓冲区创建后 和数组一样 缓冲区的大小(capacity值)将无法改变 也无法访问缓冲区外的数据 如下面的代码创建了一个大小为 的字节缓冲区 ByteBuffer byteBuffer = ByteBuffer allocate( ) 对于byteBuffer来说 只能访问属于这个缓冲区的六个字节的数据 如果超过了这个范围 将抛出一个BufferOverflowException异常 这是一个运行时错误 因为这个错误只能在程序运行时被发现 既然缓冲区和数组类似 那么缓冲区也应该象数组一样可以标识当前的位置 缓冲区的position方法为我们提供了这个功能 position方法有两种重载形式 它们的定义如下 public final int position() public final Buffer position(int newPosition) 第一个重载形式用来获取缓冲区的当前位置 在创建缓冲区后 position的初始值是 也就是缓冲区第一个元素的位置 当从缓冲区读取一个元素后 position的值加 我们从这一点可以看出 position方法返回的位置就是当前可以读取的元素的位置 position的取值范围从 到capacity – 如果position的值等于capacity 说明缓冲区当前已经没有数据可读了 position方法的第二个重载形式可以设置缓冲区的当前位置 参数newPosition的取值范围是 <= newPosition < capacity 如果newPosition的值超出这个范围 position方法就会抛出一个IllegalArgumentException异常 在大多数情况下不需要直接控制缓冲区的位置 缓冲区类提供的用于读写数据的方法可以自动地设置缓冲区的当前位置 在缓冲区类中 get和put方法用于读写缓冲区中的数据 get和put方法的定义如下 ByteBuffer类的get和put方法 public abstract byte get() public abstract ByteBuffer put(byte b) IntBuffer类的get和put方法 public abstract int get() public abstract IntBuffer put(int i) 其他五个缓冲区类中的get和put方法定义和上面的定义类似 只是get方法返回相应的数据类型 而put方法的参数是相应的数据类型 并且返回值的类型是相应的缓冲区类 每当put方法向缓冲区写入一个数据后 缓冲区的当前位置都会加 如果缓冲区的当前位置已经等于capacity 调用put方法就会抛出一个java nio BufferOverflowException异常 在缓冲区未初赋值的区域将被 填充 使用get方法可以得到缓冲区当前位置的数据 并使缓冲区的当前位置加 和put方法一样 在缓冲区当前位置等于capacity时使用get方法也会抛出java nio BufferOverflowException异常 缓冲区的初始状态如图 所示
图 缓冲区的初始状态
从图 可以看出 在缓冲区创建之初 当前的位置和缓冲区中的数据都为 当使用如下语句向缓冲区中写入数据后 缓冲区当前状态如图 所示 byteBuffer put((byte) ) byteBuffer put((byte) )
图 缓冲区的当前状态
当缓冲区的当前位置如图 所示时 使用put和get方法将会抛出上述的BufferOverflowException异常
图 当前位置处于缓冲区尾
如果要使用get方法得到缓冲区中的指定数据 必须将缓冲区的当前位置移动到指定的位置 我们可以使用position方法将当前位置移到缓冲区的任何位置 如下面的代码将图 所示的缓冲区的当前位置设为 并用get方法获得位置 的数据 byteBuffer position( ) System out println(byteBuffer get()) 上面的代码将输出 缓冲区的当前位置为除了使用position方法 也可以使用rewind方法将缓冲区的当前位置设为 rewind方法的定义如下 public final Buffer rewind() 在图 所示的缓冲区状态下调用rewind方法 就会得到如图 的缓冲区状态
图 调用rewind方法后的缓冲区状态
接下来让我们执行如下语句 System out println(byteBuffer get()) 缓冲区的状态将如图 所示
图 调用get方法后的缓冲区状态
缓冲区除了position和capacity外 还提供了一个标识来限制缓冲区可访问的范围 这个标识就是limit limit和position一样 在缓冲区类中也提供了两个重载方法 用于获得和设置limit的值 limit方法的定义如下 public final int limit() public final Buffer limit(int newLimit) 在初始状态下 缓冲区的limit和capacity值相同 但limit和capacity的区别是limit可以通过limit方法进行设置 而capacity在创建缓冲区时就已经指定了 并且不能改变 (在上面所讲的position方法的newPosition参数的取值范围时曾说是 <= newPosition < capacity 其实严格地说 应是 <= newPosition < limit)limit的其他性质和capacity一样 如在图 所示的缓冲区状态中将limit的值设为 就变成了图 所示的状态
图 将limit设为 的缓冲区状态
在这时position的值等于limit 就不能访问缓冲区的当前数据 也就是说不能使用get和put方法 否则将抛出BufferOverflowException异常 由于使用allocate创建的缓冲区并不是一次性地分配内存空间 因此 可以将缓冲区的capacity设为很大的值 如 M 缓冲区过大可能在某些环境中会使系统性能降低(如在PDA或智能插秧机中) 因此 可以使用limit方法根据具体的情况来限定缓冲区的大小 当然 limit还可以表示缓冲区中实际的数据量 这将在后面讲解 下面的代码演示了如何使用limit方法来枚举缓冲区中的数据 while(byteBuffer position() < byteBuffer limit()) System out println(byteBuffer get())
我们还可以用flip和hasRemaining方法来重写上面的代码 flip方法将limit设为缓冲区的当前位置 当limit等于position时 hasRemaining方法返回false 而则返回true flip和hasRemaining方法的定义如下 public final Buffer flip() public final boolean hasRemaining() 下面的代码演示了如何使用hasRemaining方法来枚举缓冲区中的数据 while(byteBuffer hasRemaining()) System out println(byteBuffer get()) 如果从缓冲区的第一个位置依次使用put方法向缓冲区写数据 当写完数据后 再使用flip方法 这样limit的值就等于缓冲区中实际的数据量了 在网络中传递数据时 可以使用这种方法来设置数据的结束位置 为了回顾上面所讲内容 下面的代码总结了创建缓冲区 读写缓冲区中的数据 设置缓冲区的limit和position的方法 package net; import java nio *; public class GetPutData public static void main(String[] args) // 创建缓冲区的四种方式 IntBuffer intBuffer = IntBuffer allocate( ) ByteBuffer byteBuffer = ByteBuffer allocateDirect( ) CharBuffer charBuffer = CharBuffer wrap( abcdefg ) DoubleBuffer doubleBuffer = DoubleBuffer wrap(new double[] ) // 向缓冲区中写入数据 intBuffer put( ) intBuffer put( ) System out println( intBuffer的当前位置 + intBuffer position()) intBuffer position( ) // 将缓冲区的当前位置设为 System out println(intBuffer get()) // 输出缓冲区的当前数据 intBuffer rewind() // 将缓冲区的当前位置设为 System out println(intBuffer get()) // 输出缓冲区的当前数据 byteBuffer put((byte) ) byteBuffer put((byte) ) byteBuffer flip() // 将limit设为position 在这里是 byteBuffer rewind() while(byteBuffer hasRemaining()) // 枚举byteBuffer中的数据 System out print(byteBuffer get() + ) while(charBuffer hasRemaining()) // 枚举charBuffer中的数据 System out print(charBuffer get() + ) // 枚举doubleBuffer中的数据 while(doubleBuffer position() < doubleBuffer limit()) System out print(doubleBuffer get() + ) 运行结果 intBuffer的当前位置 a b c d e f g 注意 如果必须使用缓冲区的大小来读取缓冲区的数据 尽量不要使用capacity 而要使用limit 如尽量不要写成如下的代码 while(byteBuffer position() < byteBuffer capacity()) System out println(byteBuffer get()) 这是因为当limit比capacity小时 上面的代码将会抛出一个BufferUnderflowException异常 cha138/Article/program/Java/hx/201311/26014相关参考
DataWindow的数据缓冲区 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!lishixinzh
MySQL数据库线程缓冲池详解 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! MySQL数据库线
一自我调整检查点 在以前的文章中笔者谈到过Oracle数据库中有存储缓冲区其包括三部分内容一种叫做脏缓冲存储区这个缓冲存储区中存储的是已经被修改的数据一般情况下这个数据不会马上被写入到数据文件中
Java中的缓冲区 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 如果将同步I/O方式下的数据传
JavaIO的性能可以使用标准的缓冲类提高 如果要求从磁盘上读取数据它会试图读取内存中已有的数据如果代码希望向磁盘写一些东西它可能在完成写操作前将输出在内存中存放一段时间以等待更多的数据
毕业设计有个远程协助功能得到对方的屏幕后老是会闪很是不爽今天用java的双缓冲技术解决了代码如下本类重写了Swing中的JLabel当Label重绘时会默认的调用它的update方法主要用于清除界
外排序中为何采用k路(k>)合并而不用路合并?这种技术用于内排序有意义吗?为什么?【东南大学三(分)】 .给定输入文件并设记录缓冲区个数k=写出基于败者树的外排序顺串生成算法runs输出的
设归并路数为k归并趟数为s则s=élogkù因élogkù=所以k=即最少路归并 证明由置换选择排序思想第一个归并段中第一个元素是缓冲区中最小的元素以后每选一个元素都不应小于前一个选出的元素故当
环形缓冲器Java实现 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 在数据采取时经常用户缓冲器
1窗体建立的时机问题 由于窗体属于比较占系统内存的对象所以在应用程序中何时建立窗体就变得比较重要窗体的建立时机有一下几种 ()在主窗体建立时自动建立窗体 ()在需要的时候才建立窗体然后窗体关