[Java开发之路](7)RandomAccessFile类具体解释

RandomAccessFile适用于大小已知的记录组成的文件。提供的对文件訪问。既能够读文件。也能够写文件,而且支持随机訪问文件。能够訪问文件的任何位置。

文件里记录的大小不一定都同样。仅仅要我们知道记录的大小和位置。可是该类仅限于操作文件。

RandomAccessFile不属于InputStream和OutputStream继承层次结构中的一部分。除了实现DataInput和DataOutput接口之外(DataInputStream和DataOutputStream也实现了这两个接口),它和这两个继承层次结构没有不论什么关系,它甚至不使用InputStream和OutputStream类中已经存在的不论什么功能;它是一个全然独立的类。从头開始编写其全部的方法(大多数都是本地的)。这么做是由于RandomAccessFile拥有和别的IO类型本质上不同的行为。由于我们能够在一个文件内向前和向后移动。

它是一个直接继承Object的,独立的类。

本质上说,RandomAccessFile的工作方式类似于把DataInputStream和DataOutputStream结合起来,还加入了一些方法,当中方法getFilePointer( )用来查找当前所处的文件位置。seek( )用来在文件内移至新的位置,length( )用来推断文件大小。

此外。它的构造方法还须要一个參数来表示打开模式(仅仅读方式
r 读写方式 rw)。它不支持仅仅写文件。

仅仅有RandomAccessFile支持搜寻方法(seek()),而且这种方法也仅仅适用于文件。BufferedInputStream却仅仅能同意标注(mark())位置(其值存储在内部某个变量内)和又一次设定位置(reset()),可是这些功能有限,不是很有用。

在JDK 1.4中,RandomAccessFile的绝大多数功能(但不是所有)已经被nio内存映射文件给代替了。

方法:

方法 描写叙述
void close() 关闭此随机訪问文件流并释放与该流关联的全部系统资源。

FileChannel getChannel () 返回与此文件关联的唯一 FileChannel 对象。

FileDescriptor getFD () 返回与此流关联的不透明文件描写叙述符对象。

long getFilePointer () 返回此文件里的当前偏移量,用来查找当前所处的位置。
long length() 返回此文件的长度。

int read() 从此文件里读取一个数据字节
int read(byte[] b) 将最多 b.length 个数据字节从此文件读入 byte 数组。
int read(byte[] b,int off,int len) 将最多 len 个数据字节从此文件读入 byte 数组。
boolean readBoolean() 从此文件读取一个 boolean。
byte readByte() 从此文件读取一个有符号的八位值。
char readChar() 从此文件读取一个字符
double readDouble() 从此文件读取一个 double。
float readFloat() 从此文件读取一个 float。

void readFully(byte[] b) 将 b.length 个字节从此文件读入 byte 数组,并从当前文件指针開始。
void readFully(byte[] b,int off,int len) 将正好 len 个字节从此文件读入 byte 数组,并从当前文件指针開始。

int readInt() 从此文件读取一个有符号的 32 位整数。

String readLine() 从此文件读取文本的下一行。

long readLong() 从此文件读取一个有符号的 64 位整数。

short readShort() 从此文件读取一个有符号的 16 位数。
int readUnsignedByte() 从此文件读取一个无符号的八位数
int readUnsignedShort() 从此文件读取一个无符号的 16 位数。
String readUTF() 从此文件读取一个字符串。
void seek(long pos) 设置到此文件开头測量到的文件指针偏移量,在该位置发生下一个读取或写入操作。

void setLength(long newLength) 设置此文件的长度。

int skipBytes(int n) 尝试跳过输入的 n 个字节以丢弃跳过的字节。

void write(byte[] b) 将 b.length 个字节从指定 byte 数组写入到此文件,并从当前文件指针開始。
void write(byte[] b, int off, int len) 将 len 个字节从指定 byte 数组写入到此文件。并从偏移量 off 处開始。

void write(int b) 向此文件写入指定的字节。

void writeBoolean(boolean v) 按单字节值将 boolean 写入该文件。

void writeByte(int v) 按单字节值将 byte 写入该文件
void writeBytes(String s) 按字节序列将该字符串写入该文件。
void writeChar(int v) 按双字节值将 char 写入该文件。先写高字节。

void writeChars(String s) 按字符序列将一个字符串写入该文件。
void writeDouble(double v) 使用 Double 类中的 doubleToLongBits 方法将双精度參数转换为一个 long,然后按八字节数量将该 long 值写入该文件,先定高字节。

void writeFloat(float v) 使用 Float 类中的 floatToIntBits 方法将浮点參数转换为一个 int,然后按四字节数量将该 int 值写入该文件。先写高字节。
void writeInt(int v) 按四个字节将 int 写入该文件,先写高字节。
void writeLong(long v) 按八个字节将 long 写入该文件,先写高字节
void writeShort(int v) 按两个字节将 short 写入该文件,先写高字节。

void writeUTF(String str) 使用 modified UTF-8 编码以与机器无关的方式将一个字符串写入该文件。

案例:


package com.qunar.bean;

 

import java.io.File;

import java.io.RandomAccessFile;

import java.util.Arrays;

 

public class FileDemo {

	

	public static void main(String[] args) {

		String pathname = "D:\\Recommended system.txt";

		// 创建文件实例

		File file = new File(pathname);

		

		try {

			// 推断文件是否存在

			if(!file.exists()){

				file.createNewFile();

			}//if

			

			// 读写方式打开文件

			RandomAccessFile randomAccessFile = new RandomAccessFile(file, "rw");

			System.out.println("当前所处的位置:"+randomAccessFile.getFilePointer());

			

			// write 从当前指针開始写入,写入一个字节

			randomAccessFile.write(‘A‘);

			System.out.println("当前所处的位置:"+randomAccessFile.getFilePointer());

			

			randomAccessFile.write(‘B‘);

			

			int num = 0x7fffffff;

			// 假设用write方法。每次仅仅能写一个字节。须要写4次

			randomAccessFile.write(num >>> 24);

			randomAccessFile.write(num >>> 16);

			randomAccessFile.write(num >>> 8);

			randomAccessFile.write(num);

			System.out.println("当前所处的位置:"+randomAccessFile.getFilePointer());

			

			// 或者是用writeInt方法 一次写入

			randomAccessFile.writeInt(num);

			System.out.println("当前所处的位置:"+randomAccessFile.getFilePointer());

			

			// 文件指针指向文件开头

			randomAccessFile.seek(0);

			// 一次性读取 把文件里内容都读到字节数组中

			byte[] buffer = new byte[(int)randomAccessFile.length()];

			randomAccessFile.read(buffer);

			

			for (byte b : buffer) {

				// 16进制输出

				System.out.print(Integer.toHexString(b)+" ");

			}//for

			

			randomAccessFile.close();

		} catch (Exception e) {

			e.printStackTrace();

		}

	}

}

package com.qunar.bean;

 

import java.io.File;

import java.io.RandomAccessFile;

 

public class FileDemo {

	

	public static void main(String[] args) {

		String pathname = "D:\\Recommended system.txt";

		// 创建文件实例

		File file = new File(pathname);

		

		try {

			// 推断文件是否存在

			if(!file.exists()){

				file.createNewFile();

			}//if

			

			// 读写方式打开文件

			RandomAccessFile randomAccessFile = new RandomAccessFile(file, "rw");

			

			// 写值

			for(int i = 0;i < 5;++i){

				randomAccessFile.writeInt(i);

			}//for

			

			// 将文件指针移到第二个Int值后

			randomAccessFile.seek(2*4);

			// 覆盖第三个Int值

			randomAccessFile.writeInt(6);

			

			// 文件指针指向文件开头

			randomAccessFile.seek(0);

			// 输出

			for (int i = 0;i < 5;++i) {

				System.out.print(randomAccessFile.readInt()+" ");

			}//for

			

			randomAccessFile.close();

		} catch (Exception e) {

			e.printStackTrace();

		}

	}

}

package com.qunar.bean;

 

import java.io.File;

import java.io.RandomAccessFile;

 

public class FileDemo {

	

	public static void main(String[] args) {

		String pathname = "D:\\Recommended system.txt";

		// 创建文件实例

		File file = new File(pathname);

		

		try {

			RandomAccessFile randomAccessFile = new RandomAccessFile(file, "rw");  

			

			// 下面向file文件里写数据  

			// 占4个字节  

			randomAccessFile.writeInt(2015);

			// 占8个字节

			randomAccessFile.writeDouble(12.23);  

			// 占2个字节

			randomAccessFile.writeShort(19);  

			System.out.println("当前位置:"+randomAccessFile.getFilePointer());

			randomAccessFile.writeUTF("欢迎来到小斯的博客");

			System.out.println("当前位置:"+randomAccessFile.getFilePointer());

			// 占2个字节

			randomAccessFile.writeChar(‘Y‘);  

			System.out.println("当前位置:"+randomAccessFile.getFilePointer());

			randomAccessFile.writeUTF("小斯的博客欢迎你");

			

			// 把文件指针位置设置到文件起始处  

			randomAccessFile.seek(0);

			System.out.println("读取一个Int值:"+randomAccessFile.readInt());  

			System.out.println("读取一个Double值:"+randomAccessFile.readDouble());  

			System.out.println("读取一个Short值:"+randomAccessFile.readShort()); 

			System.out.println("读取一个字符串:"+randomAccessFile.readUTF());  

			// 将文件指针跳过2个字节

			randomAccessFile.skipBytes(2);  

			System.out.println("读取一个字符串:"+randomAccessFile.readUTF());  

			

			randomAccessFile.close();

		} catch (Exception e) {

			e.printStackTrace();

		}

	}

}
时间: 2024-08-06 01:22:15

[Java开发之路](7)RandomAccessFile类具体解释的相关文章

[Java开发之路](7)RandomAccessFile类详解

RandomAccessFile适用于大小已知的记录组成的文件,提供的对文件访问,既可以读文件,也可以写文件,并且支持随机访问文件,可以访问文件的任意位置.文件中记录的大小不一定都相同,只要我们知道记录的大小和位置.但是该类仅限于操作文件. RandomAccessFile不属于InputStream和OutputStream继承层次结构中的一部分.除了实现DataInput和DataOutput接口之外(DataInputStream和DataOutputStream也实现了这两个接口),它和

[Java开发之路](6)File类的使用

1. 构造方法 构造方法 描写叙述 File(String pathname) 通过将给定的路径名字符串转换为抽象路径名来创建一个新的文件实例. File(String parent , String child) 通过给定的父路径名字符串和子路径名字符串来创建一个新的文件实例. File(File parent , String child) 通过给定的父抽象路径对象和子路径名字符串来创建一个新的文件实例. File(URI uri) 通过给定的URI来创建一个新的文件实例 package c

9.[Java开发之路](6)File类的使用

1. 构造方法 构造方法 描述 File(String pathname) 通过将给定的路径名字符串转换为抽象路径名来创建一个新的文件实例. File(String parent , String child) 通过给定的父路径名字符串和子路径名字符串来创建一个新的文件实例. File(File parent , String child) 通过给定的父抽象路径对象和子路径名字符串来创建一个新的文件实例. File(URI uri) 通过给定的URI来创建一个新的文件实例 package com

7.[Java开发之路](5)异常

1. 异常分类 在Java程序设计语言中,异常对象都是派生于Throwable类的一个实例.其是如果Java中的异常类不能满足需求,用户可以创建自己的异常类. 下图是Java异常层次结构的一个简化示意图. 从图上可以看出,所有的异常都是继承于Throwable类,但是在下一层立即分解为两个分支:Error和Exception. (1)Error Error描述了Java运行时系统的内部错误和资源耗尽错误.应用程序不应该抛出这种类型的错误,如果出现了这样的内部错误,除了通告用户,并尽力使程序安全的

[Java开发之路](20)try-with-resource 异常声明

Try-with-resources是java7中一个新的异常处理机制,它能够很容易地关闭在try-catch语句块中使用的资源. 在java7以前,程序中使用的资源需要被明确地关闭,过程有点繁琐,如下所示: package com.qunar.lectures.tryResource; import java.io.*; import java.util.ArrayList; import java.util.List; /** * Created by xiaosi on 16-3-4. *

[Java开发之路](8)图说字符串的不变性

我们用下面一组图来说明Java的不变性. 1.声明一个字符串 String s = "abcd"; s存储了字符串对象的引用.下面图片中的箭头就表示这种存储引用. 2. 将一个字符串变量赋值给另外一个字符串变量 String s2 = s; s2变量存储了同样的引用值.所以,两个变量指向同一个字符串对象. 3. 合并字符串 s = s.concat("ef"); s现在存储的是新生成的字符串对象的引用. 4. 总结 一旦一个字符串在内存(堆)上创建,这个字符串就不会

[Java开发之路](14)反射机制

1. Class类 普通对象构造方式: // 创建Book实例对象 Book book = new Book(); 对于Class的实例对象如何构造呢? Class的构造函数是私有的,只有JVM才能创建实例对象 // Class的构造函数是私有的,只有JVM才能创建Class实例对象 Class class1 = new Class(); // 错误 public final class Class<T> implements java.io.Serializable, java.lang.r

[Java开发之路](11)SAX解析XML文档

1. 简介 Dom解析功能强大,可增删改查,操作时会将XML文档读到内存,因此适用于小文档: SAX解析是从头到尾逐行逐个元素解析,修改较为不便,但适用于只读的大文档: SAX采用事件驱动的方式解析XML.套用网友的解释:如同在电影院看电影一样,从头到尾看一遍,不能回退(Dom可来来回回读取),在看电影的过程中,每遇到一个情节,都会调用大脑去接收处理这些信息.SAX也是相同的原理,每遇到一个元素节点,都会调用相应的方法来处理.在SAX的解析过程中,读取到文档开头.文档结尾,元素的开头和元素结尾都

[Java开发之路](23)装箱与拆箱

1. 简单介绍 大家对基本数据类型都很熟悉.比如 int.float.double.boolean.char 等.基本数据类型是不具备对象的特性,比方基本类型不能调用方法.功能简单. ..,为了让基本数据类型也具备对象的特性, Java 为每一个基本数据类型都提供了一个包装类,这样我们就能够像操作对象那样来操作基本数据类型. 对象包装类是不变的,即一旦构造了包装类,就不同意更改包装在当中的值. 同一时候,对象包装类还是final,因此不能定义它们的子类. 如果想定义一个整型数组列表,而尖括号里的