随机访问类(RandomAccessFile)

2024-02-08 22:32

本文主要是介绍随机访问类(RandomAccessFile),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

随机访问类(RandomAccessFile) 随机访问类(RandomAccessFile) - [] 输入流FileInputStream和输出流 FileOutputStream,实现的是对磁盘文件的顺序读写,而且读写要分别创建不同对象。相比之下RandomAccessFile类则可对文件实现随机读写操作。 RandomAccessFile对象的文件位置指针遵循下面的规律: ·新建RandomAccessFile对象的文件位置指针位于文件的开头处; ·每次读写操作之后,文件位置的指针都相应后移到读写的字节数; ·可以通过getFilePointer方法来获得文件位置指针的位置,通过seek方法来设置文件指针的位置。 如果某个文件有30个字节,读取数据过程中,从20-30读取,用skip( )//跳过方法,但在读取的过程中,前面的字节都被删除掉了,如果用户有这样的需求,先读取10-20字节,之后再读1-10之间的数,再20-30之间, java.io 随机访问文件类 RandomAccessFile java.io.RandomAccessFile 所有已实现的接口: Closeable, DataInput, DataOutput |0 ||10 ||20 ||30 | (指示器) RandomAccessFile常用方法: skipBytes(long i):从前往后拨弄指示器的位置,就是跳过多少个字节读取数据。 Void seek(long p): 对指示器作决定性的定位,用于从后往前拨弄指示器的位置。对于seek方法,拥有skipBytes( )的功能,但seek( )在使用过程非常影响系统的开销。只有万不得已的情况下使用。 例:seek(0) 指示器移到首部 RandomAccessFile类,即可以充当输入也可充当输出流。可以看作节点流。 构造方法: RandomAccessFile (”路径+文件名”, String“rw”/”r”)两个参数, //创建模式:“rw”代表写流,“r”代表读流, RandomAccessFile常用方法 Void close( ) Long length( ) Void seek( ) ##Long getFilePointer( )获得当前指针位置,默认为0 , Int read( )从文件当前位置读取一个字节 int read (byte[]b) int read (byte[]b,int off,int len) Final boolean readBoolean( )从文件当前位置读取boolean类型的一个字节 boolean在内存占1/8 Final char readChar( )从文件中读取2个字节。 Final int readInt( )从文件中读取4个字节。 ##Final String readLine( )从文件中读取一行后转为String。 Void write(byte[]b)将字节数组B中的数据写到文件中。 Void write(byte[]b,int off,int len)将 len 个字节从指定字节数组写入到此文件,并从偏移量 off 处开始。 Void write(int b)将指定的数据写到文件中。 Final void writeBoolean(boolean v)将boolean类型的值按单字节的形式写到文件中0或1 Final void writeChar(int v)将char值按2个字节写入到文件中 Final void writeChars(String s)将字符串按字符方式写入到文件中 Final void writeInt(int v)按四个字节将 int 写入该文件,先写高字节 Java代码 例:getFilePointer( ) import java.io.*; class df { public static void main(String args[])throws Exception { RandomAccessFile s=new RandomAccessFile("d:/tt.txt","rw"); System.out.println ( s.getFilePointer( ));//0 } } 例:getFilePointer( ) import java.io.*; class df { public static void main(String args[])throws Exception { RandomAccessFile s=new RandomAccessFile("d:/tt.txt","rw"); System.out.println ( s.getFilePointer( ));//0 } } 例: Java代码 import java.io.*; class RandomAccessFileDemo { public static void main(String args[])throws IOException { RandomAccessFile f=new RandomAccessFile("myfile","rw"); System.out.println ("File.lelngth:"+(f.length( ))+"B"); System.out.println ("File PointPosition:"+f.getFilePointer( )); f.seek(f.length( )); f.writeBoolean(true); f.writeBoolean(false); f.writeChar(’a’); f.writeChars("hello!"); System.out.println ("File Length;"+(f.length( ))+"B"); f.seek(0); System.out.println (f.readBoolean( )); System.out.println (f.readBoolean( )); //while(f.getFilePointer( )

这篇关于随机访问类(RandomAccessFile)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/692394

相关文章

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

AI学习指南深度学习篇-带动量的随机梯度下降法的基本原理

AI学习指南深度学习篇——带动量的随机梯度下降法的基本原理 引言 在深度学习中,优化算法被广泛应用于训练神经网络模型。随机梯度下降法(SGD)是最常用的优化算法之一,但单独使用SGD在收敛速度和稳定性方面存在一些问题。为了应对这些挑战,动量法应运而生。本文将详细介绍动量法的原理,包括动量的概念、指数加权移动平均、参数更新等内容,最后通过实际示例展示动量如何帮助SGD在参数更新过程中平稳地前进。

OpenStack中加固VNC访问安全

OpenStack中加固VNC访问安全 目录 OpenStack中加固VNC访问安全1.问题发现2.流程分析3.潜在后果4.解决方案④配置IPtables⑤VNC添加访问密码 5.参考链接 1.问题发现 很多同学使用noVNC之后都没有退出终端的习惯,往往都是用完了就直接关闭网页窗口。说这样隐患很大,如果内网里面有一些script kiddie随时都能将我们线上的虚拟

AI学习指南深度学习篇-带动量的随机梯度下降法简介

AI学习指南深度学习篇 - 带动量的随机梯度下降法简介 引言 在深度学习的广阔领域中,优化算法扮演着至关重要的角色。它们不仅决定了模型训练的效率,还直接影响到模型的最终表现之一。随着神经网络模型的不断深化和复杂化,传统的优化算法在许多领域逐渐暴露出其不足之处。带动量的随机梯度下降法(Momentum SGD)应运而生,并被广泛应用于各类深度学习模型中。 在本篇文章中,我们将深入探讨带动量的随

Qt: 详细理解delete与deleteLater (避免访问悬空指针导致程序异常终止)

前言 珍爱生命,远离悬空指针。 正文 delete 立即删除:调用 delete 后,对象会立即被销毁,其内存会立即被释放。调用顺序:对象的析构函数会被立即调用,销毁该对象及其子对象。无事件处理:如果在对象销毁过程中还涉及到信号和槽、事件处理等,直接 delete 可能会导致问题,尤其是在对象正在处理事件时。适用场景:适用于在确定对象已经不再被使用的情况下,并且不涉及异步处理或事件循环中的

Windows下安装Elasticsearch,启动报错,解决方法,访问

对于Windows用户,我们推荐使用MSI安装包进行安装。这个安装包使用图形用户界面来引导你进行安装。 首先,从这里https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.1.1.msi下载Elasticsearch 6.1.1的MSI安装包。 然后双击下载好的安装包文件启动图形化安装程序,在第一个界面,选

HDD 顺序和随机文件拷贝和存储优化策略

对于机械硬盘(HDD),顺序拷贝和随机拷贝涉及到磁头的移动方式和数据的读取/写入模式。理解这些概念对于优化硬盘性能和管理文件操作非常重要。 1. 顺序拷贝 定义: 顺序拷贝指的是数据从硬盘的一个位置到另一个位置按顺序连续读取和写入。这意味着数据在硬盘上的位置是线性的,没有跳跃或回溯。 特点: 磁头移动最小化:由于数据是连续的,磁头在读取或写入数据时只需要在磁盘的一个方向上移动,减少了寻道时