Java中的FileInputStream 和 FileOutputStream 介紹_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
FileInputStream 和 FileOutputStream 介紹
FileInputStream 是文件輸入流,它繼承于InputStream。
通常,我們使用FileInputStream從某個(gè)文件中獲得輸入字節(jié)。
FileOutputStream 是文件輸出流,它繼承于OutputStream。
通常,我們使用FileOutputStream 將數(shù)據(jù)寫入 File 或 FileDescriptor 的輸出流。
FileInputStream 函數(shù)接口
FileInputStream(File file) // 構(gòu)造函數(shù)1:創(chuàng)建“File對(duì)象”對(duì)應(yīng)的“文件輸入流” FileInputStream(FileDescriptor fd) // 構(gòu)造函數(shù)2:創(chuàng)建“文件描述符”對(duì)應(yīng)的“文件輸入流” FileInputStream(String path) // 構(gòu)造函數(shù)3:創(chuàng)建“文件(路徑為path)”對(duì)應(yīng)的“文件輸入流” int available() // 返回“剩余的可讀取的字節(jié)數(shù)”或者“skip的字節(jié)數(shù)” void close() // 關(guān)閉“文件輸入流” FileChannel getChannel() // 返回“FileChannel” final FileDescriptor getFD() // 返回“文件描述符” int read() // 返回“文件輸入流”的下一個(gè)字節(jié) int read(byte[] buffer, int byteOffset, int byteCount) // 讀取“文件輸入流”的數(shù)據(jù)并存在到buffer,從byteOffset開始存儲(chǔ),存儲(chǔ)長(zhǎng)度是byteCount。 long skip(long byteCount) // 跳過(guò)byteCount個(gè)字節(jié)
FileOutputStream 函數(shù)接口
FileOutputStream(File file) // 構(gòu)造函數(shù)1:創(chuàng)建“File對(duì)象”對(duì)應(yīng)的“文件輸入流”;默認(rèn)“追加模式”是false,即“寫到輸出的流內(nèi)容”不是以追加的方式添加到文件中。 FileOutputStream(File file, boolean append) // 構(gòu)造函數(shù)2:創(chuàng)建“File對(duì)象”對(duì)應(yīng)的“文件輸入流”;指定“追加模式”。 FileOutputStream(FileDescriptor fd) // 構(gòu)造函數(shù)3:創(chuàng)建“文件描述符”對(duì)應(yīng)的“文件輸入流”;默認(rèn)“追加模式”是false,即“寫到輸出的流內(nèi)容”不是以追加的方式添加到文件中。 FileOutputStream(String path) // 構(gòu)造函數(shù)4:創(chuàng)建“文件(路徑為path)”對(duì)應(yīng)的“文件輸入流”;默認(rèn)“追加模式”是false,即“寫到輸出的流內(nèi)容”不是以追加的方式添加到文件中。 FileOutputStream(String path, boolean append) // 構(gòu)造函數(shù)5:創(chuàng)建“文件(路徑為path)”對(duì)應(yīng)的“文件輸入流”;指定“追加模式”。 void close() // 關(guān)閉“輸出流” FileChannel getChannel() // 返回“FileChannel” final FileDescriptor getFD() // 返回“文件描述符” void write(byte[] buffer, int byteOffset, int byteCount) // 將buffer寫入到“文件輸出流”中,從buffer的byteOffset開始寫,寫入長(zhǎng)度是byteCount。 void write(int oneByte) // 寫入字節(jié)oneByte到“文件輸出流”中
示例程序
關(guān)于FileInputStream和FileOutputStream的API用法,參考示例代碼(FileStreamTest.java):
import java.io.File;
import java.io.FileDescriptor;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.PrintStream;;
import java.io.IOException;
/**
* FileInputStream 和FileOutputStream 測(cè)試程序
*
*
*/
public class FileStreamTest {
private static final String FileName = "file.txt";
public static void main(String[] args) {
testWrite();
testRead();
}
/**
* FileOutputStream 演示函數(shù)
*
* 運(yùn)行結(jié)果:
* 在源碼所在目錄生成文件"file.txt",文件內(nèi)容是“abcdefghijklmnopqrstuvwxyz”
*
* 加入,我們將 FileOutputStream fileOut2 = new FileOutputStream(file, true);
* 修改為 FileOutputStream fileOut2 = new FileOutputStream(file, false);
* 然后再執(zhí)行程序,“file.txt”的內(nèi)容變成"0123456789"。
* 原因是:
* (01) FileOutputStream fileOut2 = new FileOutputStream(file, true);
* 它是以“追加模式”將內(nèi)容寫入文件的。即寫入的內(nèi)容,追加到原始的內(nèi)容之后。
* (02) FileOutputStream fileOut2 = new FileOutputStream(file, false);
* 它是以“新建模式”將內(nèi)容寫入文件的。即刪除文件原始的內(nèi)容之后,再重新寫入。
*/
private static void testWrite() {
try {
// 創(chuàng)建文件“file.txt”對(duì)應(yīng)File對(duì)象
File file = new File(FileName);
// 創(chuàng)建文件“file.txt”對(duì)應(yīng)的FileOutputStream對(duì)象,默認(rèn)是關(guān)閉“追加模式”
FileOutputStream fileOut = new FileOutputStream(file);
// 創(chuàng)建FileOutputStream對(duì)應(yīng)的PrintStream,方便操作。PrintStream的寫入接口更便利
PrintStream out1 = new PrintStream(fileOut1);
// 向“文件中”寫入26個(gè)字母
out1.print("abcdefghijklmnopqrstuvwxyz");
out1.close();
// 創(chuàng)建文件“file.txt”對(duì)應(yīng)的FileOutputStream對(duì)象,打開“追加模式”
FileOutputStream fileOut2 = new FileOutputStream(file, true);
// 創(chuàng)建FileOutputStream對(duì)應(yīng)的PrintStream,方便操作。PrintStream的寫入接口更便利
PrintStream out2 = new PrintStream(fileOut2);
// 向“文件中”寫入"0123456789"+換行符
out2.println("0123456789");
out2.close();
} catch(IOException e) {
e.printStackTrace();
}
}
/**
* FileInputStream 演示程序
*/
private static void testRead() {
try {
// 方法:新建FileInputStream對(duì)象
// 新建文件“file.txt”對(duì)應(yīng)File對(duì)象
File file = new File(FileName);
FileInputStream in1 = new FileInputStream(file);
// 方法2:新建FileInputStream對(duì)象
FileInputStream in2 = new FileInputStream(FileName);
// 方法3:新建FileInputStream對(duì)象
// 獲取文件“file.txt”對(duì)應(yīng)的“文件描述符”
FileDescriptor fdin = in2.getFD();
// 根據(jù)“文件描述符”創(chuàng)建“FileInputStream”對(duì)象
FileInputStream in3 = new FileInputStream(fdin);
// 測(cè)試read(),從中讀取一個(gè)字節(jié)
char c1 = (char)in1.read();
System.out.println("c1="+c1);
// 測(cè)試skip(long byteCount),跳過(guò)4個(gè)字節(jié)
in1.skip(25);
// 測(cè)試read(byte[] buffer, int byteOffset, int byteCount)
byte[] buf = new byte[10];
in1.read(buf, 0, buf.length);
System.out.println("buf="+(new String(buf)));
// 創(chuàng)建“FileInputStream”對(duì)象對(duì)應(yīng)的BufferedInputStream
BufferedInputStream bufIn = new BufferedInputStream(in3);
// 讀取一個(gè)字節(jié)
char c2 = (char)bufIn.read();
System.out.println("c2="+c2);
in1.close();
in2.close();
in3.close();
} catch(IOException e) {
e.printStackTrace();
}
}
}
運(yùn)行結(jié)果:
c1=a buf=0123456789 c2=a
結(jié)果說(shuō)明:
運(yùn)行程序,會(huì)在源碼所在位置新生成一個(gè)文件“file.txt”。它的內(nèi)容是“abcdefghijklmnopqrstuvwxyz0123456789”。
以上所述是小編給大家介紹的Java中的FileInputStream 和 FileOutputStream 介紹,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
MyBatis Properties及別名定義實(shí)例詳解
這篇文章主要介紹了MyBatis Properties及別名定義實(shí)例詳解,需要的朋友可以參考下2017-08-08
Java中ByteBuffer的allocate方法 和allocateDirect方法的區(qū)別和選用原則解析
在Java中,ByteBuffer是java.nio包中的一個(gè)類,用于處理字節(jié)數(shù)據(jù),ByteBuffer提供了兩種方式來(lái)分配內(nèi)存:allocate和allocateDirect,這篇文章主要介紹了Java中ByteBuffer的allocate方法 和allocateDirect方法的區(qū)別和選用原則 ,需要的朋友可以參考下2023-12-12
MyBatis3傳遞多個(gè)參數(shù)(Multiple Parameters)
這篇文章主要介紹了MyBatis3傳遞多個(gè)參數(shù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
Spring Data JPA實(shí)現(xiàn)動(dòng)態(tài)查詢的兩種方法
本篇文章主要介紹了Spring Data JPA實(shí)現(xiàn)動(dòng)態(tài)查詢的兩種方法,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-04-04
SpringCloud-Nacos服務(wù)注冊(cè)與發(fā)現(xiàn)方式
這篇文章主要介紹了SpringCloud-Nacos服務(wù)注冊(cè)與發(fā)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
JDK動(dòng)態(tài)代理,代理接口沒(méi)有實(shí)現(xiàn)類,實(shí)現(xiàn)動(dòng)態(tài)代理方式
這篇文章主要介紹了JDK動(dòng)態(tài)代理,代理接口沒(méi)有實(shí)現(xiàn)類,實(shí)現(xiàn)動(dòng)態(tài)代理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
Java使用ffmpeg和mencoder實(shí)現(xiàn)視頻轉(zhuǎn)碼
這篇文章主要為大家詳細(xì)介紹了Java使用ffmpeg和mencoder實(shí)現(xiàn)視頻轉(zhuǎn)碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12

