• @author luozhao
• @since JDK 1.8
_/
public class RandomAccessStreamHua {
static public int blockSize=0;
public static void main(String[] args) {
File file=new File(“abc.txt”);
RandomAccessFile randomAccessFile=null;
try {
//构建一个指向File文件的随机流,并且该随机流式读随机流
randomAccessFile=new RandomAccessFile(file,“r”);
//获取我要要读取文件的大小
int length= (int) randomAccessFile.length();
//定义我每次要读取的块大小
blockSize=1024;
//我一共要读取howLump这么多块,并且最后一次读取的数一定小于1024
int howLump= (int) Math.ceil(length_1.0/blockSize);
System.err.printf(“%s---------%d-----------%s”,“总共要被分为”,howLump,“块”);
System.out.println();
//判断我每次到底读取多少
int actualSize= length>blockSize?blockSize:length;
int beginPos=0;
for (int i = 0; i <howLump ; i++) {
//每次读取的位置都不一样
beginPos=i*1024;
if (i==(howLump-1)){
actualSize=length;
}else {
actualSize=blockSize;
length-=blockSize;
}
//主要是分割文本文件,这里可以不用err
System.out.printf(“%s–%d–%s----%s----%d”,“起始位置第”,i+1,“块”,“读取数据大小”,actualSize);
System.out.println();
readLump(i,beginPos,actualSize);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
randomAccessFile.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
public static void readLump(int i,int beginPos,int actualSize){
RandomAccessFile randomAccessFile=null;
try {
//创建一个只读文件abc.txt随机流
randomAccessFile= new RandomAccessFile(“abc.txt”,“r”);
//顶一个字节大小为1024单位的字节数组
byte[] buff=new byte[blockSize];
//用来跟踪当前随机流读取的指针
int read=0;
//定义每次从文件abc.txt文件中开始读取的位置
randomAccessFile.seek(beginPos);
//判断我当前文件有没有读取完毕,没读取完毕继续读,读取完毕后跳出。
while((read=randomAccessFile.read(buff))!=-1){
//如果说我一次性要读取文件的长度大于abc.txt文件内容的长度,那么直接把缓存字节数组打印
if (actualSize> read){
System.out.println(new String(buff));
}else{
//因为我把正abc.txt划分为几个部分后,每个部分的长度可能不一致,主要是最后一快大小与前面的大小不一致
//所以说这个时候的字节数组buff里面存储的数据,就是文本文件abc.txt中,起始位置beginPos~read=-1之前的数据
//而我只需要打印输出这其中一部分的数据即可。
System.out.println(new String(buff,0,actualSize ));
}
}