溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

java使用RandomAccessFile類基于指針讀寫(xiě)文件的示例分析

發(fā)布時(shí)間:2021-06-24 09:29:00 來(lái)源:億速云 閱讀:191 作者:小新 欄目:編程語(yǔ)言

小編給大家分享一下java使用RandomAccessFile類基于指針讀寫(xiě)文件的示例分析,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

java API中提供了一個(gè)基于指針操作實(shí)現(xiàn)對(duì)文件隨機(jī)訪問(wèn)操作的類,該類就是RandomAccessFile類,該類不同于其他很多基于流方式讀寫(xiě)文件的類。它直接繼承自O(shè)bject。

public class RandomAccessFile extends Objectimplements DataOutput, DataInput, Closeable{...}

1.使用該類時(shí)可以指定對(duì)要操作文件的讀寫(xiě)模式。

第一種模式是只讀模式,第二種模式是讀寫(xiě)模式。在創(chuàng)建該類實(shí)例時(shí)指定。

@Test 
  public void test01() throws IOException{
//讀寫(xiě)模式 
    RandomAccessFile r=new RandomAccessFile(new File(""),"rw" ); 
	//只讀模式 
	//<span >RandomAccessFile r=new RandomAccessFile(new File(""),"r" );</span> 
    r.write(1);//寫(xiě)出一個(gè)字節(jié),寫(xiě)出的是int值的低8位 
    r.close(); 
    r.read();//每次讀一個(gè)字節(jié),填充到int的低八位 
  }

2.字節(jié)讀取操作

(1)void write(int d):寫(xiě)出該int值的低8位,其他位舍棄

@Test 
  public void testWrite() throws IOException{ 
    RandomAccessFile file=new RandomAccessFile(new File("emp.txt"),"rw"); 
    file.write(97);//0110 0001 
    file.write(98);//0110 0010 
    file.write(99);//0110 0011 
  }

(2)int read():注意:該方法只會(huì)從文件中當(dāng)前指針處讀取一個(gè)byte(8位)的數(shù)據(jù)填充到int返回值的第八位,其他位用0填充。若該方法返回0,則代表讀到文件末尾。

以上兩種方法使用起來(lái)當(dāng)然會(huì)很麻煩。

RandomAccessFile類中還封裝了對(duì)8中基本數(shù)據(jù)類型的讀寫(xiě)操作,使用起來(lái)會(huì)很方便。

分別為

readByte(), readShort(), readInt(), readLong(), readFloat(),readDouble(),readBoolean(),readChar()

返回值類型均為對(duì)應(yīng)的基本數(shù)據(jù)類型。同時(shí)相應(yīng)的也有這八中writeByte()...方法。這是在流式讀寫(xiě)文件中所不具有的。

3.文件指針操作

RandomAccessFile類的所有讀寫(xiě)操作均是基于指針的,指針會(huì)隨著讀或?qū)懙牟僮魍笠苿?dòng)。同時(shí)也可以通過(guò)方法自由的操作指針的位置,以此更方便的讀寫(xiě)文件。

常用方法

(1)long getFilePointer():該方法用于返回當(dāng)前指針位置。默認(rèn)讀寫(xiě)操作時(shí),指針的初始位置為文件的第一個(gè)字節(jié)處,即值為0
(2)void seek(long pos):該方法可以設(shè)定指針位置
(3)int skipBytes(int n):該方法可以跳過(guò)n個(gè)字節(jié)

/** 
 * RandomAccessFile:基于指針讀寫(xiě),總是在指針當(dāng)前位置讀寫(xiě),無(wú)論讀寫(xiě),指針都會(huì)向后移動(dòng) 
 * RandomAccessFile總是在指針當(dāng)前位置進(jìn)行讀寫(xiě)字節(jié),并且無(wú)論進(jìn)行了讀還是寫(xiě)一個(gè)字節(jié)后, 
 * 指針都會(huì)自動(dòng)向后移動(dòng)到下一個(gè)字節(jié)的位置 
 * 默認(rèn)創(chuàng)建出來(lái)RandomAccessFile時(shí),指針位置為0,即:文件的第一個(gè)字節(jié)的位置 
 * @author zc 
 */ 
public class T13RandomAccessFile { 
  public static void main(String[] args) throws IOException { 
    RandomAccessFile raf=new RandomAccessFile(new File("emp.txt"),"rw"); 
    int a=255; 
    //雖然能寫(xiě)入,但是在記事本中打開(kāi)仍是亂碼字符 
    raf.write(a>>>24);//11111111 
    raf.write(a>>>16); 
    raf.write(a>>>8); 
    raf.write(a); 
    //獲取當(dāng)前指針位置 
    long pos=raf.getFilePointer(); 
    //!!注意,返回值是字節(jié)4,前面寫(xiě)入的四個(gè)字節(jié)對(duì)應(yīng)從0--3字節(jié) 
    System.out.println("pos:"+pos);//4 
    //將int值分成四部分,寫(xiě)入 
    raf.writeInt(255); 
    System.out.println("pos:"+raf.getFilePointer());//8 
    raf.writeLong(255);//long八個(gè)字節(jié) 
    System.out.println("pos:"+raf.getFilePointer());//16 
    raf.writeFloat(8);//float四個(gè)字節(jié) 
    System.out.println("pos:"+raf.getFilePointer());//20 
    raf.writeDouble(12.1);//double八個(gè)字節(jié) 
    System.out.println("pos:"+raf.getFilePointer());//28 
    raf.write(new byte[]{1,1}); 
    raf.writeBoolean(false); 
    raf.writeChar(1); 
    //此時(shí)已經(jīng)寫(xiě)完,指針指向文件某位 
    System.out.println(raf.read());//-1 
    /* 
     *void seek(long pos) 
     *將指針移動(dòng)到指定位置 
     * */ 
    raf.seek(0); 
    System.out.println("point:"+raf.getFilePointer());//0 
    //讀取剛剛寫(xiě)入的long值 
    raf.seek(8); 
    long l=raf.readLong(); 
    System.out.println("讀出的long值:"+l);//255 
    //讀取剛剛寫(xiě)入的double值 
    raf.seek(20); 
    System.out.println(raf.readDouble());//12.1 
    raf.close(); 
  } 
}

看完了這篇文章,相信你對(duì)“java使用RandomAccessFile類基于指針讀寫(xiě)文件的示例分析”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI