RandomAccessFile(转)

来源:互联网 发布:战舰世界 青叶 数据 编辑:程序博客网 时间:2024/05/01 01:55
 
2011-06-20

RandomAccessFile(转)

    博客分类:
  • j2se
F#

RandomAccessFile是一个很有用的类,可以将字节流写入到磁盘文件中,对应的也可以从磁盘文件中读取出字节流,在API中关于RandomAccessFile的描述如下:

此类的实例支持对随机访问文件的读取和写入。随机访问文件的行为类似存储在文件系统中的一个大型 byte 数组。存在指向该隐含数组的光标或索引,称为文件指针 ;输入操作从文件指针开始读取字节,并随着对字节的读取而前移此文件指针。如果随机访问文件以读取/写入模式创建,则输出操作也可用;输出操作从文件指针开始写入字节,并随着对字节的写入而前移此文件指针。写入隐含数组的当前末尾之后的输出操作导致该数组扩展。该文件指针可以通过getFilePointer 方法读取,并通过 seek 方法设置。

 

通常,如果此类中的所有读取例程在读取所需数量的字节之前已到达文件末尾,则抛出 EOFException (是一种IOException )。如果由于某些原因无法读取任何字节,而不是在读取所需数量的字节之前已到达文件末尾,则抛出 IOException ,而不是EOFException 。需要特别指出的是,如果流已被关闭,则可能抛出 IOException

以下是两个RandomAccessFile的写入和读取的简单例子:

1、  将字节流写入到磁盘中

Java代码 复制代码 收藏代码
  1. private static void testCreateFile(){   
  2.   
  3. String directory = “D:/program/test”;   
  4.   
  5. String name = “t.gen”;   
  6.   
  7. File f = new File(directory, name);   
  8.   
  9. RandomAccessFile file = null;   
  10.   
  11. try {   
  12.   
  13. file = new RandomAccessFile(f, “rw”);   
  14.   
  15. byte[] b = {5,10,15,20};   
  16.   
  17. try {   
  18.   
  19. //如果没有这行,文件也会生成,只是文件为空  
  20.   
  21. file.write(b,0,4);   
  22.   
  23. catch (IOException e) {   
  24.   
  25. e.printStackTrace();   
  26.   
  27. }   
  28.   
  29. catch (FileNotFoundException e) {   
  30.   
  31. e.printStackTrace();   
  32.   
  33. }finally{   
  34.   
  35. if (null!=file){   
  36.   
  37. try {   
  38.   
  39. file.close();   
  40.   
  41. catch (IOException e) {   
  42.   
  43. e.printStackTrace();   
  44.   
  45. }   
  46.   
  47. }   
  48.   
  49. }   
  50.   
  51. }  
 
Java代码 复制代码 收藏代码
  1. 2、  从磁盘文件中读取字节流   
  2.   
  3. private static void testReadFile(){   
  4.   
  5. String directory = “D:/program/luceneDemo3.0/test”;   
  6.   
  7. String name = “t.gen”;   
  8.   
  9. File f = new File(directory, name);   
  10.   
  11. RandomAccessFile file = null;   
  12.   
  13. try {   
  14.   
  15. file = new RandomAccessFile(f, “rw”);   
  16.   
  17. byte[] b = new byte[4];   
  18.   
  19. try {   
  20.   
  21. long len = file.length();   
  22.   
  23. file.read(b);   
  24.   
  25. //设置要读取的字节位置   
  26.   
  27. file.seek(1);   
  28.   
  29. System.out.println(file.readByte()+”>>FilePointer>>”+file.getFilePointer());   
  30.   
  31. for (int i=0;i<b.length;i++){   
  32.   
  33. System.out.println(“>>>”+b[i]);   
  34.   
  35. }   
  36.   
  37. catch (IOException e) {   
  38.   
  39. e.printStackTrace();   
  40.   
  41. }   
  42.   
  43. catch (FileNotFoundException e) {   
  44.   
  45. e.printStackTrace();   
  46.   
  47. }finally{   
  48.   
  49. if (null!=file){   
  50.   
  51. try {   
  52.   
  53. file.close();   
  54.   
  55. catch (IOException e) {   
  56.   
  57. e.printStackTrace();   
  58.   
  59. }   
  60.   
  61. }   
  62.   
  63. }   
  64.   
  65. }  
 

说明

1、  这个类依我看来,用来处理字节流(byte)是很好的,如果用来处理字符(串)或其他数据类型,比如int、long,我试了感觉效果并不好,尤其是处理中文字符串的时候,那简直就是一个灾难,你会又碰上纠缠不清的乱码!

2、 seek(long pos)方法

是在读取的时候用来设置读取到哪一个字节的,比如在例子中有5,10,15,20字节,在byte数组中分别对应0、1、2、3位置,同样在文件 file = new RandomAccessFile(f, “rw”);中,也对应着0、1、2、3位置,所以如果设置file.seek(1);就表示通过file.readByte()读取的时候,读取的是第 1位置的数据,也就是10了。

3、  getFilePointer()方法

在通过上面说的seek (long pos)设置后,getFilePointer()得到的就是当前文件中的字节位置,也就是所说的偏移量了。比如在这个例子中,getFilePointer()的值就是1.

4、文件模式

“r” 以只读方式打开。调用结果对象的任何 write 方法都将导致抛出 IOException。

“rw” 打开以便读取和写入。如果该文件尚不存在,则尝试创建该文件。

“rws” 打开以便读取和写入,对于 “rw”,还要求对文件的内容或元数据的每个更新都同步写入到底层存储设备。

“rwd”   打开以便读取和写入,对于 “rw”,还要求对文件内容的每个更新都同步写入到底层存储设备。

附录

voidclose ()
关闭此随机访问文件流并释放与该流关联的所有系统资源。
FileChannelgetChannel ()
返回与此文件关联的唯一 FileChannel 对象。
FileDescriptorgetFD ()
返回与此流关联的不透明文件描述符对象。
longgetFilePointer ()
返回此文件中的当前偏移量。
longlength ()
返回此文件的长度。
intread ()
从此文件中读取一个数据字节。
intread (byte[] b)
将最多 b.length 个数据字节从此文件读入 byte 数组。
intread (byte[] b, int off, int len)
将最多 len 个数据字节从此文件读入 byte 数组。
booleanreadBoolean ()
从此文件读取一个 boolean。
bytereadByte ()
从此文件读取一个有符号的八位值。
charreadChar ()
从此文件读取一个字符。
doublereadDouble ()
从此文件读取一个 double。
floatreadFloat ()
从此文件读取一个 float。
voidreadFully (byte[] b)
将 b.length 个字节从此文件读入 byte 数组,并从当前文件指针开始。
voidreadFully (byte[] b, int off, int len)
将正好 len 个字节从此文件读入 byte 数组,并从当前文件指针开始。
intreadInt ()
从此文件读取一个有符号的 32 位整数。
StringreadLine ()
从此文件读取文本的下一行。
longreadLong ()
从此文件读取一个有符号的 64 位整数。
shortreadShort ()
从此文件读取一个有符号的 16 位数。
intreadUnsignedByte ()
从此文件读取一个无符号的八位数。
intreadUnsignedShort ()
从此文件读取一个无符号的 16 位数。
StringreadUTF ()
从此文件读取一个字符串。
voidseek (long pos)
设置到此文件开头测量到的文件指针偏移量,在该位置发生下一个读取或写入操作。
voidsetLength (long newLength)
设置此文件的长度。
intskipBytes (int n)
尝试跳过输入的 n 个字节以丢弃跳过的字节。
voidwrite (byte[] b)
将 b.length 个字节从指定 byte 数组写入到此文件,并从当前文件指针开始。
voidwrite (byte[] b, int off, int len)
将 len 个字节从指定 byte 数组写入到此文件,并从偏移量 off 处开始。
voidwrite (int b)
向此文件写入指定的字节。
voidwriteBoolean (boolean v)
按单字节值将 boolean 写入该文件。
voidwriteByte (int v)
按单字节值将 byte 写入该文件。
voidwriteBytes (String s)
按字节序列将该字符串写入该文件。
voidwriteChar (int v)
按双字节值将 char 写入该文件,先写高字节。
voidwriteChars (String s)
按字符序列将一个字符串写入该文件。
voidwriteDouble (double v)
使用 Double 类中的 doubleToLongBits 方法将双精度参数转换为一个 long,然后按八字节数量将该 long 值写入该文件,先定高字节。
voidwriteFloat (float v)
使用 Float 类中的 floatToIntBits 方法将浮点参数转换为一个 int,然后按四字节数量将该 int 值写入该文件,先写高字节。
voidwriteInt (int v)
按四个字节将 int 写入该文件,先写高字节。
voidwriteLong (long v)
按八个字节将 long 写入该文件,先写高字节。
voidwriteShort (int v)
按两个字节将 short 写入该文件,先写高字节。
voidwriteUTF (String str)
使用 modified UTF-8 编码以与机器无关的方式将一个字符串写入该文件。
原创粉丝点击