欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談Java幾種文件讀取方式耗時

 更新時間:2023年04月13日 10:45:40   作者:15130140362  
本文主要介紹了淺談Java幾種文件讀取方式耗時,主要介紹了4種,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

項目中經(jīng)常會遇到文件讀寫,不同的讀寫方式速度之間有多大差異呢?

這里自己沒有使用外部的依賴庫,使用Java原生的文件讀寫方法:

測試文件大小,7.1M

BufferedReader

代碼:

    public static String ReadFileByBufferReaderToString(String path) {
        if (TextUtils.isEmpty(path)) {
            return "";
        }
        StringBuilder stringBuilder = new StringBuilder();
        try (BufferedReader bufferedReader = new BufferedReader(new FileReader(path))) {
            String tempStr;
            while ((tempStr = bufferedReader.readLine()) != null) {
                stringBuilder.append(tempStr).append(System.lineSeparator());
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
        return stringBuilder.toString();
    }

這里我們使用stringbuilder去存儲讀取出來的字符串,加日志查看耗時,讀取一個

onClick: readFileByBufferReaderStringBuilder tims use is 86

這里將文件讀取出來之后存儲方式改下,每次創(chuàng)建新的String字符串,測試一下每次創(chuàng)建新的字符串和使用StringBuilder之間的性能差異:

    public static String ReadFileByBufferReaderToStringUseString(String path) {
        if (TextUtils.isEmpty(path)) {
            return "";
        }
        String result = "";
        try (BufferedReader bufferedReader = new BufferedReader(new FileReader(path))) {
            String tempStr;
            while ((tempStr = bufferedReader.readLine()) != null) {
                result += tempStr;
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
        Log.i(TAG, "ReadFileToString: read success ");
        return result;
    }

 2023-04-08 23:06:06.141 18416-18518/com.example.androidstart I/TestFileReadSpeed: onClick: readFileByBufferReaderString tims use is 264041

花了264041 ms,可見多次創(chuàng)建String對象對性能消耗非常大,所以字符串拼接的時候一定要使用StringBuilder,不能使用String直接相加

Files.readAllBytes

    @RequiresApi(api = Build.VERSION_CODES.O)
    public static String ReadFileByReadAllBytesReaderToString(String path) {
        if (TextUtils.isEmpty(path)) {
            return "";
        }
        String result = null;
        try {
            result = new String(Files.readAllBytes(Paths.get(path)));
        } catch (IOException e) {
            e.printStackTrace();
        }
        return result;
    }

2023-04-09 17:38:06.989 7078-7359/com.example.androidstart I/TestFileReadSpeed: onClick: ReadFileByReadAllBytesReaderToString tims use is 68

耗時68ms,比上面的BufferReader行一行讀取會快一些,但是這個API有一些限制就是必須在AndroidO及以上版本才可以使用。

Files.lines

    @RequiresApi(api = Build.VERSION_CODES.O)
    public static String ReadFileByByFilesReadLinesToString(String path) {
        if(TextUtils.isEmpty(path)){
            return "";
        }
        StringBuilder stringBuilder = new StringBuilder();
        try (Stream<String> stream = Files.lines(Paths.get(path))) {
            stream.forEach(new Consumer<String>() {
                @Override
                public void accept(String s) {
                    stringBuilder.append(s);
                }
            });
        } catch (IOException e) {
            e.printStackTrace();
        }
        return stringBuilder.toString();
    }

2023-04-09 17:46:14.342 7078-7078/com.example.androidstart I/TestFileReadSpeed: onClick: ReadFileByByFilesReadLinesToString tims use is 102

Files.lines耗時中等在100ms左右。

CommonIO::readFileToString

代碼:

   public static String ReadFileByCommonIOReadFileToString(String path) {
        if (TextUtils.isEmpty(path)) {
            return "";
        }
        try {
            return FileUtils.readFileToString(new File(path), Charset.defaultCharset());
        } catch (IOException e) {
            e.printStackTrace();
        }
        return "";
    }

2023-04-09 17:53:34.204 8292-8292/com.example.androidstart I/TestFileReadSpeed: onClick: ReadFileByCommonIOReadFileToString tims use is 70

耗時為70ms

綜上:(Files.readAllBytes 和 FileUtils.readFileToString耗時想近) 優(yōu)于 (BufferReader和Files.lines耗時相近)

到此這篇關(guān)于淺談Java幾種文件讀取方式耗時的文章就介紹到這了,更多相關(guān)Java 文件讀取內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java:String.split()特殊字符處理操作

    Java:String.split()特殊字符處理操作

    這篇文章主要介紹了Java:String.split()特殊字符處理操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • 如何使用try-with-resource機制關(guān)閉連接

    如何使用try-with-resource機制關(guān)閉連接

    這篇文章主要介紹了使用try-with-resource機制關(guān)閉連接的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Mybatis?selectKey 如何返回新增用戶的id值

    Mybatis?selectKey 如何返回新增用戶的id值

    這篇文章主要介紹了Mybatis?selectKey 如何返回新增用戶的id值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 數(shù)據(jù)庫CURD必備搭檔mybatis?plus詳解

    數(shù)據(jù)庫CURD必備搭檔mybatis?plus詳解

    這篇文章主要為大家介紹了數(shù)據(jù)庫CURD必備搭檔mybatis?plus詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • springboot集成redis lettuce

    springboot集成redis lettuce

    目前java操作redis的客戶端有jedis跟Lettuce。本文主要介紹了springboot集成redis lettuce,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 基于Java的Scoket編程

    基于Java的Scoket編程

    本文詳細講解了基于Java的Scoket編程,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • 詳解JDK9特性之JPMS模塊化

    詳解JDK9特性之JPMS模塊化

    JDK9引入了一個特性叫做JPMS(Java Platform Module System),也可以叫做Project Jigsaw。模塊化的本質(zhì)就是將一個大型的項目拆分成為一個一個的模塊,每個模塊都是獨立的單元,并且不同的模塊之間可以互相引用和調(diào)用。本文將詳細介紹JDK9特性之JPMS模塊化。
    2021-06-06
  • 面向?qū)ο缶幊?Java中的抽象數(shù)據(jù)類型

    面向?qū)ο缶幊?Java中的抽象數(shù)據(jù)類型

    面向?qū)ο缶幊?Java中的抽象數(shù)據(jù)類型...
    2006-12-12
  • SpringBoot jar包大小優(yōu)化問題及解決

    SpringBoot jar包大小優(yōu)化問題及解決

    這篇文章主要介紹了SpringBoot jar包大小優(yōu)化問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Activiti explorer.war示例工程使用過程圖解

    Activiti explorer.war示例工程使用過程圖解

    這篇文章主要介紹了Activiti explorer.war示例工程使用過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-03-03

最新評論