使用RandomAccessFile读写数据

------------siwuxie095

工程名:TestRandomAccessFile

包名:com.siwuxie095.file

类名:MultiWriteFile.java(主类)、WriteFile.java

工程结构目录如下:

WriteFile.java:


package com.siwuxie095.file;

import java.io.File;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.io.RandomAccessFile;

//WriteFile 继承自 Thread,作为一个线程

//RandomAccessFile:

//在写入时,可以为每一个线程指定一个固定的写入区域,

//这可以用于多线程的下载,以及多线程的文件传输

//在读取时,也可以指定RandomAccessFile来读取文件中的特定内容

public class WriteFile extends Thread {

//声明三个本地变量

File file;

int block;

int L=100;

/**

* 如:将一个文件均匀划分成 5 个区域,每一个区域都是一个块 block,

* 每个block的长度设为100字节

* 构造方法中传入的block数值是几,就从哪个块开始读写

*

* 1         2         3         4         5

* |---------|---------|---------|---------|---------|

* 0xL       1xL       2xL

*

* @param f

* @param b

*/

//先为线程创建一个构造方法,传入两个参数

//一个是要写的文件,另一个是当前线程所负责的写入文件的区块

public WriteFile(File f,int b) {

this.file=f;

this.block=b;

}

//在当前类中覆盖 Thread 的 run() 方法,并重写

@Override

public void run() {

try {

//创建一个 RandomAccessFile 随机读写文件,并指定操作的文件对象和操作模式

//操作模式有4种:(一般情况下都使用 rw)

//(1)r 只读

//(2)rw 可读可写

//(3)rws 可读可写,还要求对"文件的内容"或"元数据"的每个更新都同步写入到基础存储设备

//(4)rwd 可读可写,还要求对"文件的内容"的每个更新都同步写入到基础存储设备

//有异常抛出,需要用 try catch 捕获

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

//通过随机读写文件,可以读取到或写入到当前文件的任何一个位置

/*如:一个文件对象,有头和尾,中间是文件内容

*

* 如果想从(1)处写入文件数据,可以将 RandomAccessFile 的指针移动到(1)处,

* 直接开始写入,以后的数据依次从(1)处向后写入

*

* 如果想从(2)处写入3个加号,同理,3个加号就出现在(2)处

*

* 如果想从某个位置读取数据,同样要移动文件的指针到该位置,

* 然后开始读取相应数量的数据

*

*      (1)           (2)

*       |***          |+++

* |------***-----------+++--------------------|

* 文件头                                                                              文件尾

*/

//调用 RandomAccessFile 的 seek()方法设定文件的指针

//通过文件自身的指针,设定读取或写入的偏移量,

//然后指针自动向后偏移。

//对于每一个文件,根据传入的block值来确定读写的位置

//block是从1开始的,但文件的指针是从0开始的

//使用(block-1)*L

//这样就将文件的指针指定到当前线程所负责的区域的头部

raf.seek((block-1)*L);

//调用 writeBytes() 方法写入文件:传入字符串,会自动

//将字符串转换成字节写入到文件当中

//这里的 block 虽然是整型,但会自动转换为String

raf.writeBytes("This is block "+block);

//再输出20个短横

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

raf.writeBytes("-");

}

//关闭RandomAccessFile

raf.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

}

MultiWriteFile.java:


package com.siwuxie095.file;

import java.io.File;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.io.RandomAccessFile;

public class MultiWriteFile {

//先在主类中创建一个静态文件对象,使用相对路径

static File file=new File("test.txt");

public static void main(String[] args) {

//判断文件是否存在

if (file.exists()) {

//如果存在就先将文件删除掉,保证每次写入,当前文件都是一个新文件

//不会被之前的文件版本所影响

//这里不必担心当前的线程无法向该文件写入数据

//因为在 RandomAccessFile 写入文件时,文件不存在,它会自动把文件创建出来

file.delete();

}

//写入文件:

//创建WriteFile,指定不同线程写入不同的区块,并开启线程

//写入文件的顺序与线程的先后创建顺序无关,严格按照指定的区块去写

new WriteFile(file,5).start();

new WriteFile(file,3).start();

new WriteFile(file,1).start();

new WriteFile(file,4).start();

new WriteFile(file,2).start();

try {

//读取文件:

RandomAccessFile raf=new RandomAccessFile(file, "r");

//这里要读取第5个区块,即指针从400开始

raf.seek(400);

//调用 read()方法时要传入一个字节型的数组,并指定读取的长度

byte input[]=new byte[20];

raf.read(input);

//创建String,传入字节型数组input

String inputString=new String(input);

System.out.println(inputString);

raf.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

}

运行一览:

读取第 5 个区块的 20 个字节:

test.txt 的内容:

test.txt 共 435 字节:4x100+35

(最后35个字节即 This is block 5--------------------)

运行后,工程结构目录一览:

【made by siwuxie095】

时间: 2024-10-29 02:38:39

使用RandomAccessFile读写数据的相关文章

IO流18 --- RandomAccessFile实现数据的读写操作 --- 技术搬运工(尚硅谷)

RandomAccessFile实例化时,需要设置读写模式 示例:复制文件 @Test public void test16() throws IOException { RandomAccessFile rafR = new RandomAccessFile("FLAMING MOUNTAIN.JPG", "r"); RandomAccessFile rafW = new RandomAccessFile("FLAMING MOUNTAIN2.JPG&q

01. SQL Server 如何读写数据

原文:01. SQL Server 如何读写数据 一. 数据读写流程简要SQL Server作为一个关系型数据库,自然也维持了事务的ACID特性,数据库的读写冲突由事务隔离级别控制.无论有没有显示开启事务,事务都是存在的.流程图如下: 数据读写流程图 0. 事务开始(1) 所有DML语句必然是基于事务的,如果没有显式开启事务,即手动写下BEGIN TRAN,SQL Server则把每条语句作为一个事务,并自动提交事务. 也就是说SQL SERVER 默认不开启隐式事务,这点与ORACLE正好相反

inputstream和outputstream读写数据模板代码

//读写数据模板代码 byte buffer[] = new byte[1024]; int len=0; while((len=in.read(buffer))>0){ out.write(buffer,0,len); }

读写数据块函数--fread( )和fwrite( )函数

读写数据块函数--fread( )和fwrite( )函数    调用方式分别为:    (1) .fread(buffer,size,count,fp): 该函数将fp指向的文件的数据以数据块的形式读入内存buffer    (2).write(buffer,size,count,fp):该函数将内存buffer的内容以数据块的形式写入fp指向的文件.    其中:buffer:是一个指针.对于fread来说 它是读入数据的有效地址.对 fwrite来说,是要写盘的数据地址(起始地址). si

【转】iphone 输入/输出流异步读写数据

原文:iphone 输入/输出流异步读写数据 分类: iphone2012-05-30 14:50 2484人阅读 评论(1) 收藏 举报 iphoneattributesinterfacepathstreamfile 1.首先是往文件里写入数据 WriteFile.h [cpp] view plaincopy #import <Foundation/Foundation.h> #import <UIKit/UIKit.h> @class NoteDb; @interface Wr

如何选择容器,主要从存放要求和读写数据效率两方面考虑

1 ,存放要求 无序:set,不能重复. 有序:List,允许重复 “key-value”对:Map 2 ,读写效率 Hash:两者都最高 Array:读快改慢 Linked:读慢改快 Tree:加入元素可排序使用 如何选择容器,主要从存放要求和读写数据效率两方面考虑,布布扣,bubuko.com

ADO.NET学习笔记-读写数据

1. DbCommand对象 要读写数据,一是需要有效的数据链接,二是需要DbCommand对象向数据源传递SQL命令.DbCommand对象包含的命令可以是DML数据操作语言,也可以是DDL数据定义语言.创建DbCommand的最好方式是先创建DbConnection,然后使用DbConnection的CreateCommand()方法,这样创建的DbCommand与DbConnection之间最为匹配.DbCommand必备的两个重要属性为CommandText和CommandType,示例

Android中向SD卡读写数据,读SD卡和手机内存

package com.example.sdoperation; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.FileReader; import android.support.v7.app.Actio

HDFS读写数据块--${dfs.data.dir}选择策略

最近工作需要,看了HDFS读写数据块这部分.不过可能跟网上大部分帖子不一样,本文主要写了${dfs.data.dir}的选择策略,也就是block在DataNode上的放置策略.我主要是从我们工作需要的角度来读这部分代码的. 1 hdfs-site.xml 2 <property> 3 <name>dfs.data.dir</name> 4 <value>/mnt/datadir1/data,/mnt/datadir2/data,/mnt/datadir3/