java IO流 之 輸入流 InputString()的使用
本文主要給大家介紹java的InputStream 流的使用。
(1)FileInputstream: 子類,讀取數(shù)據(jù)的通道
使用步驟:
1.獲取目標文件:new File()
2.建立通道:new FileInputString()
3.讀取數(shù)據(jù):read()
4.釋放資源:close()
//一些默認要導入的包 import java.io.File; import java.io.FileInputStream; import java.io.IOException;
public static void main(String[] args) throws IOException { // TODO Auto-generated method stub //分別調用方法查看效果 test1(); System.out.println("-------------------------------------------"); test2(); System.out.println("-------------------------------------------"); test3(); System.out.println("-------------------------------------------"); test4(); }
(2)讀取數(shù)據(jù)的三種方式
1.直接讀取 (一次只能一個字節(jié))
int date = fileInputStream.read(); char date3 = (char)fileInputStream.read();
//方式一 直接打印 public static void test1() throws IOException{ //(1)獲取目標文件路徑 File file = new File("C:\\Users\\joke\\Desktop\\Demo1.java"); //(2)根據(jù)目標文件路徑 建立通道: new FileInputStream(file) FileInputStream fileInputStream = new FileInputStream(file); //(3)讀取數(shù)據(jù) :read(); int date = fileInputStream.read();//這里是int類型 int date2 = fileInputStream.read();// char date3 = (char)fileInputStream.read(); //以char類型顯示 System.out.println(date+"\\"+date2+"\\"+date3); //(4)釋放資源 fileInputStream.close(); }
2.單獨使用for循環(huán)(效率低)
for(int i = 0; i < file.length();i++){ System.out.print((char)fileInputStream.read()); }
//方式二 循環(huán)遍歷 public static void test2() throws IOException{ //通過時間測試效率 long startTime = System.currentTimeMillis(); File file = new File("C:\\Users\\joke\\Desktop\\Demo1.java"); FileInputStream fileInputStream = new FileInputStream(file); //for循環(huán) for(int i = 0; i < file.length();i++){ System.out.print((char)fileInputStream.read()); } fileInputStream.close(); long endTime = System.currentTimeMillis(); System.out.println("讀取文件所花時間:"+(endTime-startTime)); }
3.Byte[ ] 緩沖區(qū)(只能讀取指定的字節(jié)數(shù)不能讀取一個完整的文件)
byte[] bt = new byte[1024]; int count = fileInputStream.read(bt); System.out.println(new String (bt,0,count));
//方式三 創(chuàng)建緩沖區(qū)(只能讀取制定的大小,不能讀取一個完整的文件) public static void test3() throws IOException{ File file = new File("C:\\Users\\joke\\Desktop\\Demo1.java"); FileInputStream fileInputStream = new FileInputStream(file); //創(chuàng)建緩沖區(qū),加快讀取數(shù)據(jù),確定要讀取的字節(jié)大小 byte[] bt = new byte[1024]; //read() 讀取字節(jié) int count = fileInputStream.read(bt); System.out.println(count); //顯示讀取到的字節(jié)數(shù) System.out.println(new String (bt,0,count));//將字節(jié)轉為字符串顯示 fileInputStream.close(); }
4.緩沖區(qū)和循環(huán)結合。緩沖區(qū)一般設置為1024的倍數(shù)。理論上設置的緩沖區(qū)越大,讀取效率越高
byte[] bt = new byte[1024]; int count = 0; while((count = fileInputStream.read(bt)) != -1){ System.out.println(new String (bt,0,count)); }
//方式四 循環(huán)與緩沖區(qū)結合(效率高) public static void test4() throws IOException{ //通過時間測試效率 long startTime = System.currentTimeMillis(); File file = new File("C:\\Users\\joke\\Desktop\\Demo1.java"); FileInputStream fileInputStream = new FileInputStream(file); //緩沖區(qū)一般設置為1024的倍數(shù)。理論上設置的緩沖區(qū)越大,讀取效率越高 byte[] bt = new byte[1024]; int count = 0; //read返回 -1 時,證明已經(jīng)遍歷完 while((count = fileInputStream.read(bt)) != -1){ //字符串型顯示(從bt中的第0個字節(jié)開始遍歷count個長度) System.out.println(new String (bt,0,count)); } fileInputStream.close(); long endTime = System.currentTimeMillis(); System.out.println("讀取文件所花時間:"+(endTime-startTime)); }
陌陌說:
在以上,對比第二個和第四個方法,會發(fā)現(xiàn)方法四的效率是比較高的,所以推薦使用的四個方法
在這里我們是直接拋出異常,除了拋出之外我們還可以使用
try{ }cater{ }finally{ }
的方式來處理異常
以上所述是小編給大家介紹的java IO流 之 輸入流 InputString()的使用,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
springboot如何實現(xiàn)異步響應請求(前端請求超時的問題解決)
這篇文章主要給大家介紹了關于springboot如何實現(xiàn)異步響應請求(前端請求超時的問題解決)的相關資料,文中通過實例代碼介紹的非常詳細,對大家學習或者使用springboot具有一定的參考學習價值,需要的朋友可以參考下2023-01-01SpringCloud之Zuul網(wǎng)關原理及其配置講解
這篇文章主要介紹了SpringCloud之Zuul網(wǎng)關原理及其配置講解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03Spring Cloud Feign文件傳輸?shù)氖纠a
微服務中通常使用 Feign 作為服務消費者,那么如何使用 Feign 接口傳輸文件呢?這篇文章主要介紹了Spring Cloud Feign文件傳輸?shù)氖纠a,感興趣的小伙伴們可以參考一下2018-06-06Java 靜態(tài)數(shù)據(jù)初始化的示例代碼
這篇文章主要介紹了Java 靜態(tài)數(shù)據(jù)初始化的示例代碼,幫助大家更好的理解和學習Java,感興趣的朋友可以了解下2020-09-09