`
gxhslcww
  • 浏览: 76854 次
  • 性别: Icon_minigender_1
  • 来自: 南通
社区版块
存档分类
最新评论

java RandomAccessFile

阅读更多

  1. 学习时还是要多个心眼,不要太依赖IDE,以至于很多细节都忽略了。

比如,String类里有个toUpperCase(),如果 有个String str="abc",str.toUpperCase()后,问你str变化没?答案是没有,打印出 str还是“abc",  估计这个方法的内部,Java就是另外定义了一个新的字符串变量,把变化好的字符赋给新的定义的字符串,老的字符串还是没有改变的。
2. 整型常量有3种表示方式:

	
①十进制整数。例如,123、一456、0。
        ②八进制整数。以0开头的整数是八进制数
。例如,0123表示8进制数123<8),等于十进制数83。
        ③十六进制整数。以ox或0x开头的整数是十六进制数
。例如,0x1.23或0Xl 23表示十六进制数123…),等于十进制数291。
如果在整型常量后面加上字母u或u,则表示无符号整数(unsigned int)。例如,123U或123u是unsigned int型的。
如果在整型常量后面加上一个字母L或l,则表示长整数(10ngint)。例如,123[.或123l是long int型的。 Integer.toHexString(i)是十进制转换为十六进制,Integer.toOctalString(i)是十进制转换为八进制,这些单词记下比较好。

      3. 对于RandomAccessFile类,我平常也没用过他,只是见过,既然笔试碰到了,我就关注下,这个类是用来访问那些保存数据记录的文件的,你就可以用seek( )方法来访问记录,并进行读写了。这些记录的大小不必相同;但是其大小和位置必须是可知的。但是该类仅限于操作文件。
java RandomAccessFile - qingying_109 - xiaopengyan_109 的博客

 执行的结果如下:

java RandomAccessFile - qingying_109 - xiaopengyan_109 的博客
 
你会发现,一个double占8个字节,RandomAccessFile有定位功能,而且,读完第六个数后,自己指向第七个数,所以,在这个基础上,你再执行后面的rf.writeDouble(47.ooo1),它就是覆盖第七个数了。
RandomAccessFile 不属于InputStream和OutputStream类系的。实际上,除了实现DataInput和 DataOutput接口之外(DataInputStream和DataOutputStream也实现了这两个接口),它和这两个类系毫不相干,甚至 不使用InputStream和OutputStream类中已经存在的任何功能;它是一个完全独立的类,所有方法(绝大多数都只属于它自己)都是从零开 始写的。这可能是因为RandomAccessFile能在文件里面前后移动,所以它的行为与其它的I/O类有些根本性的不同。总而言之,它是一个直接继 承Object的,独立的类。

基本上,RandomAccessFile的工作方式是,把DataInputStream和 DataOutputStream结合起来,再加上它自己的一些方法,比如定位用的getFilePointer( ),在文件里移动用的seek( ),以及判断文件大小的length( )、skipBytes()跳过多少字节数。此外,它的构造函数还要一个表示以只读方式("r"),还是以读写方式("rw")打开文件的参数 (和C的fopen( )一模一样)。它不支持只写文件。

只有RandomAccessFile才有seek搜寻方法,而这个方法也只适 用于文件。BufferedInputStream有一个mark( )方法,你可以用它来设定标记(把结果保存在一个内部变量里),然后再调用reset( )返回这个位置,但是它的功能太弱了,而且也不怎么实用。

使用该版本的开发人员需文件随机存取,就得使用RandomAccessFile类。其I/O性能较之其它常用开发语言的同类性能差距甚远,严重影响程序的运行效率。

开发人员迫切需要提高效率,下面分析RandomAccessFile等文件类的源代码,找出其中的症结所在,并加以改进优化,创建一个"性/价比"俱佳的随机文件访问类BufferedRandomAccessFile。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics