快速业务通道

hibernate3学习笔记(九) Query及HQL - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-20
声明要检索的位置。

直接 vs. 间接

既然已经了解了典型的缓冲区,那么让我们研究直接缓冲区与间接缓冲区之间的差别。在创建缓冲区时,可以要求创建直接缓冲区,创建直接缓冲区的成本要比创建间接缓冲区高,但这可以使运行时环境直接在该缓冲区上进行较快的本机 I/O 操作。因为创建直接缓冲区所增加的成本,所以直接缓冲区只用于长生存期的缓冲区,而不用于短生存期、一次性且用完就丢弃的缓冲区。而且,只能在 ByteBuffer 这个级别上创建直接缓冲区,如果希望使用其它类型,则必须将 Buffer 转换成更具体的类型。为了演示,清单 3 中代码的行为与清单 2 的行为一样,但清单 3 使用直接缓冲区:

清单 3. 列出网络接口

import java.nio.*; public class ReadDirectBuff {   public static void main(String args[]) {    if (args.length != 0) {     String arg = args[0];     int size = arg.length();     ByteBuffer byteBuffer = ByteBuffer.allocateDirect(size*2);     CharBuffer buff = byteBuffer.asCharBuffer();     buff.put(arg);     buff.rewind();     for (int i=0, n=buff.length(); i<n; i++) {      System.out.println(i + " : " + buff.get());     }    }   } }

在上面的代码中,请注意,不能只是将 String 包装在直接 ByteBuffer 中。必须首先创建一个缓冲区,先填充它,然后将位置倒回起始点,这样才能从头读。还要记住,字符长度是字节长度的两倍,因此示例中会有 size*2 。

Merlin的魔力: Merlin的新I/O缓冲区的输入和输出(3)

时间:2011-02-02 IBM John Zukowski

内存映射文件

第 8 种 Buffer 类型 MappedByteBuffer 只是一种特殊的 ByteBuffer 。 MappedByteBuffer 将文件所在区域直接映射到内存。通常,该区域包含整个文件,但也可以只映射部分文件。所以,必须指定要映射文件的哪部分。而且,与其它 Buffer 对象一样,这里没有构造函数;必须让 java.nio.channels.FileChannel 的 map() 方法来获取 MappedByteBuffer 。此外,无需过多涉及通道就可以用 getChannel() 方法从 FileInputStream 或 FileOutputStream 获取 FileChannel 。通过从命令行传入文件名来读取文本文件的内容,清单 4 显示了 MappedByteBuffer :

清单 4. 读取内存映射文本文件

import java.io.*; import java.nio.*; import java.nio.channels.*; import java.nio.charset.*; public class ReadFileBuff {   public static void main(String args[]) throws IOException {    if (args.length != 0) {     String filename = args[0];     FileInputStream fis = new FileInputStream(filename);     FileChannel channel = fis.getChannel();     int length = (int)channel.size();     MappedByteBuffer byteBuffer =      channel.map(FileChannel.MapMode.READ_ONLY, 0, length);     Charset charset = Charset.forName("ISO-8859-1");     CharsetDecoder decoder = charset.newDecoder();     CharBuffer charBuffer = decoder.decode(byteBuffer);     for (int i=0, n=charBuffer.length(); i<n; i++) {      System.out.print(charBuffer.get());     }    }   } }

正如我在“字符集”(请参阅 参考资料)这篇文章中所解释的,由于文件有内容,必须告诉系统如何将字节转换成字符。因此需要使用 Charset 。

结束语

由 Buffer 支撑的 J2SE 新的 I/O 包从根本上改变了 Java 技术处理 I/O 操作的方式。在阅读完本文之后,您应该了解了 NIO 从基本的 get 和 put 操作到读取内存映

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号