Java中的FileInputStream 和 FileOutputStream 介紹_動力節(jié)點(diǎn)Java學(xué)院整理
FileInputStream 和 FileOutputStream 介紹
FileInputStream 是文件輸入流,它繼承于InputStream。
通常,我們使用FileInputStream從某個文件中獲得輸入字節(jié)。
FileOutputStream 是文件輸出流,它繼承于OutputStream。
通常,我們使用FileOutputStream 將數(shù)據(jù)寫入 File 或 FileDescriptor 的輸出流。
FileInputStream 函數(shù)接口
FileInputStream(File file) // 構(gòu)造函數(shù)1:創(chuàng)建“File對象”對應(yīng)的“文件輸入流” FileInputStream(FileDescriptor fd) // 構(gòu)造函數(shù)2:創(chuàng)建“文件描述符”對應(yīng)的“文件輸入流” FileInputStream(String path) // 構(gòu)造函數(shù)3:創(chuàng)建“文件(路徑為path)”對應(yīng)的“文件輸入流” int available() // 返回“剩余的可讀取的字節(jié)數(shù)”或者“skip的字節(jié)數(shù)” void close() // 關(guān)閉“文件輸入流” FileChannel getChannel() // 返回“FileChannel” final FileDescriptor getFD() // 返回“文件描述符” int read() // 返回“文件輸入流”的下一個字節(jié) int read(byte[] buffer, int byteOffset, int byteCount) // 讀取“文件輸入流”的數(shù)據(jù)并存在到buffer,從byteOffset開始存儲,存儲長度是byteCount。 long skip(long byteCount) // 跳過byteCount個字節(jié)
FileOutputStream 函數(shù)接口
FileOutputStream(File file) // 構(gòu)造函數(shù)1:創(chuàng)建“File對象”對應(yīng)的“文件輸入流”;默認(rèn)“追加模式”是false,即“寫到輸出的流內(nèi)容”不是以追加的方式添加到文件中。 FileOutputStream(File file, boolean append) // 構(gòu)造函數(shù)2:創(chuàng)建“File對象”對應(yīng)的“文件輸入流”;指定“追加模式”。 FileOutputStream(FileDescriptor fd) // 構(gòu)造函數(shù)3:創(chuàng)建“文件描述符”對應(yīng)的“文件輸入流”;默認(rèn)“追加模式”是false,即“寫到輸出的流內(nèi)容”不是以追加的方式添加到文件中。 FileOutputStream(String path) // 構(gòu)造函數(shù)4:創(chuàng)建“文件(路徑為path)”對應(yīng)的“文件輸入流”;默認(rèn)“追加模式”是false,即“寫到輸出的流內(nèi)容”不是以追加的方式添加到文件中。 FileOutputStream(String path, boolean append) // 構(gòu)造函數(shù)5:創(chuàng)建“文件(路徑為path)”對應(yīng)的“文件輸入流”;指定“追加模式”。 void close() // 關(guān)閉“輸出流” FileChannel getChannel() // 返回“FileChannel” final FileDescriptor getFD() // 返回“文件描述符” void write(byte[] buffer, int byteOffset, int byteCount) // 將buffer寫入到“文件輸出流”中,從buffer的byteOffset開始寫,寫入長度是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 測試程序 * * */ 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”對應(yīng)File對象 File file = new File(FileName); // 創(chuàng)建文件“file.txt”對應(yīng)的FileOutputStream對象,默認(rèn)是關(guān)閉“追加模式” FileOutputStream fileOut = new FileOutputStream(file); // 創(chuàng)建FileOutputStream對應(yīng)的PrintStream,方便操作。PrintStream的寫入接口更便利 PrintStream out1 = new PrintStream(fileOut1); // 向“文件中”寫入26個字母 out1.print("abcdefghijklmnopqrstuvwxyz"); out1.close(); // 創(chuàng)建文件“file.txt”對應(yīng)的FileOutputStream對象,打開“追加模式” FileOutputStream fileOut2 = new FileOutputStream(file, true); // 創(chuàng)建FileOutputStream對應(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對象 // 新建文件“file.txt”對應(yīng)File對象 File file = new File(FileName); FileInputStream in1 = new FileInputStream(file); // 方法2:新建FileInputStream對象 FileInputStream in2 = new FileInputStream(FileName); // 方法3:新建FileInputStream對象 // 獲取文件“file.txt”對應(yīng)的“文件描述符” FileDescriptor fdin = in2.getFD(); // 根據(jù)“文件描述符”創(chuàng)建“FileInputStream”對象 FileInputStream in3 = new FileInputStream(fdin); // 測試read(),從中讀取一個字節(jié) char c1 = (char)in1.read(); System.out.println("c1="+c1); // 測試skip(long byteCount),跳過4個字節(jié) in1.skip(25); // 測試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”對象對應(yīng)的BufferedInputStream BufferedInputStream bufIn = new BufferedInputStream(in3); // 讀取一個字節(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é)果說明:
運(yùn)行程序,會在源碼所在位置新生成一個文件“file.txt”。它的內(nèi)容是“abcdefghijklmnopqrstuvwxyz0123456789”。
以上所述是小編給大家介紹的Java中的FileInputStream 和 FileOutputStream 介紹,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
關(guān)于Java企業(yè)級項(xiàng)目開發(fā)思想
Java企業(yè)級項(xiàng)目開發(fā)思想。偶遇,讀有所得,遂分享給大家,本文不涉及案例,只談思想和理念,需要的朋友可以參考。2017-09-09Spring事務(wù)框架之TransactionStatus源碼解析
這篇文章主要為大家介紹了Spring事務(wù)框架之TransactionStatus源碼示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08使用list stream:對List中的對象先進(jìn)行排序再獲取前n個對象
這篇文章主要介紹了使用list stream:對List中的對象先進(jìn)行排序再獲取前n個對象,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09Java打包之后讀取Resources下的文件失效原因及解決方法
這篇文章主要給大家介紹了Java打包之后讀取Resources下的文件失效的問題分析和解決方法,文中通過代碼示例和圖文結(jié)合給大家講解非常詳細(xì),需要的朋友可以參考下2023-12-12java打印表格 將ResultSet中的數(shù)據(jù)打印成表格問題
這篇文章主要介紹了java打印表格 將ResultSet中的數(shù)據(jù)打印成表格問題。具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12解決spring @ControllerAdvice處理異常無法正確匹配自定義異常
這篇文章主要介紹了解決spring @ControllerAdvice處理異常無法正確匹配自定義異常的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06springmvc使用JSR-303進(jìn)行數(shù)據(jù)校驗(yàn)實(shí)例
本篇文章主要介紹了詳解springmvc使用JSR-303進(jìn)行數(shù)據(jù)校驗(yàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-02-02SpringBoot異步使用@Async的原理以及線程池配置詳解
在項(xiàng)目中當(dāng)訪問其他人的接口較慢時,不想程序一直卡在耗時任務(wù)上,想程序能夠并行執(zhí)行,我們可以使用多線程來并行的處理任務(wù),也可以使用spring提供的異步處理方式@Async,這篇文章主要給大家介紹了關(guān)于SpringBoot異步使用@Async的原理以及線程池配置的相關(guān)資料2021-09-09