關于BufferedReader的讀取效率問題
BufferedReader的讀取效率
1. 一般情況
正常采用readline讀取,一行行讀取。
readline要注意阻塞的情況,當一行沒有"/r"、"/n"、"/r/n"就會阻塞在那。
InputStreamReader isr = new InputStreamReader(connection.getInputStream(), "UTF-8"); in = new BufferedReader(isr); String line; while ((line = in.readLine()) != null) { result += line; }
2. 采用read+CharBuffer
inputStream = connection.getInputStream(); isr = new InputStreamReader(inputStream, "UTF-8"); in = new BufferedReader(isr); CharBuffer bos = CharBuffer.allocate(20480); StringBuilder builder = new StringBuilder(); while (in.read(bos) != -1) { bos.flip(); builder.append(bos.toString()); }
注:bos.flip()作用是將指針指向緩沖區(qū)的開頭
經過一千條數據的讀取,發(fā)現采用read+CharBuffer的效率要比readline來的高效的多?。。?!
補充:
后續(xù)實驗中發(fā)現,其實并不是read方法和CharBuffer高效。其實是String對象頻繁的創(chuàng)建導致效率低下,使用CharBuffer和StringBuilder解決了這一問題。
OJ系統(tǒng)里用BufferedReader提高效率
在OJ系統(tǒng)中做編程題時,如果從System.in讀入的數據非常大的時候,使用Scanner非常影響效率,可能導致最終代碼超時,所以最好改用BufferedReader來讀取字符數據。
例如:
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Main { public static void main(String[]args) { BufferedReader buf=null; buf=new BufferedReader(new InputStreamReader(System.in)); String str=null; try { int a= Integer.parseInt(buf.readLine()); double b=Double.parseDouble(buf.readLine()); } catch (IOException e) { e.printStackTrace(); } System.out.println(); } }
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
IntelliJ IDEA中properties文件顯示亂碼問題的解決辦法
今天小編就為大家分享一篇關于IntelliJ IDEA中properties文件顯示亂碼問題的解決辦法,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10SpringBoot整合RabbitMQ及生產全場景高級特性實戰(zhàn)
本文主要介紹了SpringBoot整合RabbitMQ及生產全場景高級特性實戰(zhàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10response.setContentType()參數以及作用詳解
這篇文章主要介紹了response.setContentType()參數以及作用詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下2021-08-08