review28
前面介绍了指向文件的输入流和输出流。随机流是既能读文件也能写文件。
RandomAccessFile类创建的流称做随机流,与前面的输入、输出流不同的是,RandomAccessFile类既不是InputStream类的子类,也不是OutputStream类的子类。但是RandomAccessFile类创建的流既可以作为流的源,也可以作为流的目的地,换句话说,当准备对一个文件进行读写操作时,创建一个指向该文件的随机流即可,这样既可以从这个流中读取文件中的数据,也可以通过这个流写入数据到文件。
以下是RandomAccessFile类的两个构造方法。
RandomAccessFile(String name, String mode)参数name用来确定一个文件名,给出创建的流的源,也是流目的地。参数mode取r(只读)或rw(可读写),决定创建的流对文件的访问权利。
RandomAccessFile(File file, String mode)参数file是一个File对象,给出创建的流的源,也是流的目的地。参数mode取r(只读)或rw(可读写),决定创建的流对文件的访问权利。
RandomAccessFile流指向文件时,不刷新文件。
RandomAccessFile类中有一个方法seek(long a)用来定位RandomAccessFile流的读写位置,其中参数a确定读写位置距离文件开头的字节个数。
另外流还可以调用getFilePointer()方法获取流的当前位置。RandomAccessFile流对文件的读写比顺序读写更为灵活。
代码展示如下所示:
import java.io.IOException;
import java.io.RandomAccessFile; public class Test10 { public static void main(String[] args) {
// TODO Auto-generated method stub
RandomAccessFile inAndOut = null;
int data[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; try {
inAndOut = new RandomAccessFile("E:/test/test03.txt", "rw");
for(int i = 0; i < data.length; i++)
{
inAndOut.writeInt(data[i]);//这是作为输出流
}
for(long i = data.length - 1; i >= 0; i--)
{
inAndOut.seek(i * 4);
System.out.printf(" %d", inAndOut.readInt());//这是作为输入流
}
inAndOut.close();
}
catch (IOException e)
{ } } }
程序运行后,在test03.txt文件中将会写入10个整数,然后并在控制台输出这10个整数。截图如下所示:

需要注意的是,RandomAccessFile流的readLine()方法在读取含有非ASCII字符的文件时(比如含有汉字的文件)会出现“乱码”现象,因此,需要把readLine()读取的字符串用“iso-8859-1”编码重新编码存放到byte数组中,然后再用当前机器的默认编码将该数组转化为字符串。
import java.io.IOException;
import java.io.RandomAccessFile; public class Test11 { public static void main(String[] args) {
// TODO Auto-generated method stub
RandomAccessFile in = null;
try{
in = new RandomAccessFile("E:/test/test01.txt", "rw");
long length = in.length();
long position = 0;
in.seek(position);
while(position < length)
{
String str = in.readLine();
byte b[] = str.getBytes("iso-8859-1");
str = new String(b);
position = in.getFilePointer();
System.out.println(str);
}
in.close();
}
catch(IOException e){}
} }
程序运行之后会把test01.txt的数据读出并显示出来。

字节流读取数据使用的是字节数组,字符流读取数据使用的是字符数组,缓冲流读取数据的时候使用的是字符串,用readLine()来实现读取一个文本行。
随机流读取数据的时候像缓冲流一样使用readLine()方法。
随机流与其他流不一样的地方在于它可以从指定位置开始读取数据。
总结
从以上分析可以看出RandomAccessFile最大两个特点:
1.可以指定位置开始操作;
2.既可以读,也可以写;
review28的更多相关文章
随机推荐
- 不恰当使用线程池处理 MQ 消息引起的故障
现状 业务部门反应网站访问特别慢,负责运维监控的同事说MQ消息队列积压了,中间件的说应用服务器内存占用很高,GC 一直回收不了内存,GC 线程占了近 100% 的 CPU,其他的基本上都在等待,数据库 ...
- IOS自动布局的Problem
今天为做一个小小的footerView我的心脏差点气出来... 第一步 新建一个view xib文件 第二步 新建一个UIview的类 第三步 在UIview中间放一个Lable,添加约束,水平垂直居 ...
- 简单的 ajax demo
2.最重要也是最核心的是要自己改下bootstrap-paginator.js源文件,如下: [javascript] view plain copy function oneferRepo ...
- setlocale()函数测试当前语言的两个程序
http://www.cnblogs.com/cnyao/archive/2010/05/06/1729220.html setlocale()函数是用来配置地域信息的,原本以为这个也是windows ...
- 关于主键(PRIMARY KEY)和自增(AUTO_INCREMENT)结合使用的知识点
1.主键(PRIMARY KEY)和自增(AUTO_INCREMENT)同时使用两种写法: a.主键(PRIMARY KEY)和自增(AUTO_INCREMENT)分两行写 创建一 ...
- Linux基础系列:常用命令(2)
作业一: 1) 新建用户natasha,uid为1000,gid为555,备注信息为“master” groupadd -g 555 natasha useradd -u 1000 -g 555 -c ...
- 小程序 height100% Android ios上的不同表现
Android还是按原图显示 ios,会完全覆盖
- Mysql主从复制原理详解
一.为什么要做主从同步 1.读写分离,降低对主数据库的IO消耗 2.避免数据丢失 3.提高业务系统性能 二.主从同步和集群的区别 1.主从同步 一般需要两台及以上数据库服务器即可(一台用于写入数据,一 ...
- python配置文件操作
步骤: 1.导入模块 import configparser 2.创建实例 cf = configparser.ConfigParser() 3.读取配置文件,若配置文件中有中文,则需设置编码格式 ...
- centos7环境下zookeeper的搭建步骤之单机伪集群
首先说明:这里是单机版的伪集群搭建 第一步:下载zookeeper:zookeeper的下载地址: http://mirror.bit.edu.cn/apache/zookeeper/ 第二步:安装: ...