Java中的Scanner、BufferedReader?和?StreamTokenizer使用詳解
1. Scanner 的使用與分析
簡介:
Scanner
是 Java 中一個用于解析原始類型(如 int
、double
等)和字符串的類。它通常從輸入流中逐個讀取數(shù)據(jù)并進行解析,支持多種分隔符的使用。其方法比較靈活,能夠處理不同類型的數(shù)據(jù)輸入。
常用方法:
nextLine()
:讀取一行文本。nextInt()
:讀取一個整數(shù)。nextDouble()
:讀取一個浮點數(shù)。next()
:讀取一個單詞。
性能:
Scanner
相較于 BufferedReader
在性能上稍遜一籌,尤其是在大量數(shù)據(jù)輸入時,因為每次讀取時都要進行格式檢查和解析。
錯誤處理:
Scanner
在讀取不符合格式的數(shù)據(jù)時,通常會拋出異常,需要通過異常處理來管理。
適用場景:
適用于簡單、格式規(guī)范的輸入,尤其是處理基本數(shù)據(jù)類型的輸入時。
代碼示例:Scanner 的基本使用
import java.util.Scanner; public class ScannerExample { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.println("Enter a string:"); String inputString = scanner.nextLine(); // 讀取一行文本 System.out.println("You entered: " + inputString); System.out.println("Enter an integer:"); int inputInt = scanner.nextInt(); // 讀取整數(shù) System.out.println("You entered the number: " + inputInt); System.out.println("Enter a double:"); double inputDouble = scanner.nextDouble(); // 讀取浮點數(shù) System.out.println("You entered the double: " + inputDouble); scanner.close(); } }
2. BufferedReader 的使用與分析
簡介:
BufferedReader
是 Java 中一個用于讀取字符輸入流的類。它提供了緩沖功能,可以減少每次讀取時的 I/O 操作,從而提高性能。通常,BufferedReader
用于逐行讀取數(shù)據(jù)。
常用方法:
readLine()
:讀取一行文本。read()
:讀取單個字符。
性能:
BufferedReader
通過緩沖機制提高了讀取大量數(shù)據(jù)的性能,尤其是在處理文件讀取時表現(xiàn)得尤為明顯。
錯誤處理:
BufferedReader
對于錯誤的輸入通常不會拋出異常,而是返回 null
,需要顯式判斷和處理。
適用場景:
適用于處理大量文本輸入,尤其是對性能有較高要求的場景。它適合從文件或者標準輸入中讀取大塊數(shù)據(jù)。
代碼示例:BufferedReader 的基本使用
import java.io.BufferedReader; import java.io.InputStreamReader; import java.io.IOException; public class BufferedReaderExample { public static void main(String[] args) { BufferedReader reader = new BufferedReader(new InputStreamReader(System.in)); try { System.out.println("Enter a line of text:"); String input = reader.readLine(); // 讀取一行文本 System.out.println("You entered: " + input); } catch (IOException e) { e.printStackTrace(); } finally { try { reader.close(); } catch (IOException e) { e.printStackTrace(); } } } }
3. StreamTokenizer 的使用與分析
簡介:
StreamTokenizer
是 Java 中用于將輸入流分割為標記(tokens)的類。它通過讀取字符流并按指定規(guī)則將輸入流中的字符切割為有意義的單詞、數(shù)字等標記,適合用來解析結(jié)構(gòu)化文本。
常用方法:
nextToken()
:讀取下一個標記。ttype
:標記的類型(如單詞、數(shù)字等)。sval
:當前標記的字符串值。nval
:當前標記的數(shù)字值。
性能:
StreamTokenizer
在解析文本時性能較高,因為它以流的形式逐字符地讀取輸入,不會占用過多內(nèi)存。
錯誤處理:
StreamTokenizer
在遇到無法識別的字符時會跳過,直到下一個有效的標記。它通常不會拋出異常。
適用場景:
適用于需要精確控制標記化輸入流的場景,尤其是在文本分析和解析時。
代碼示例:StreamTokenizer 的基本使用
import java.io.*; import java.util.*; public class Main { static StreamTokenizer st = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in))); public static void main(String[] args) throws IOException { int n = nextInt(); } public static int nextInt() throws IOException { st.nextToken(); return (int)st.nval; } }
import java.io.BufferedReader; import java.io.InputStreamReader; import java.io.IOException; import java.io.StreamTokenizer; public class StreamTokenizerExample { public static void main(String[] args) throws IOException { BufferedReader reader = new BufferedReader(new InputStreamReader(System.in)); System.out.println("Enter some text:"); processTokens(reader); // 處理輸入的標記 } /** * 處理輸入的文本并打印每個標記。 * @param reader 輸入流 * @throws IOException 讀取流時拋出的異常 */ public static void processTokens(BufferedReader reader) throws IOException { // 創(chuàng)建 StreamTokenizer 對象 StreamTokenizer tokenizer = new StreamTokenizer(reader); // 遍歷輸入流,處理每個標記 while (tokenizer.nextToken() != StreamTokenizer.TT_EOF) { processTokenByType(tokenizer); // 根據(jù)標記類型處理 } } /** * 根據(jù)不同的標記類型處理輸入 * @param tokenizer StreamTokenizer 對象 */ public static void processTokenByType(StreamTokenizer tokenizer) { try { switch (tokenizer.ttype) { case StreamTokenizer.TT_WORD: System.out.println("Word: " + tokenizer.sval); // 處理單詞 break; case StreamTokenizer.TT_NUMBER: System.out.println("Number: " + tokenizer.nval); // 處理數(shù)字 break; case StreamTokenizer.TT_EOL: System.out.println("End of line encountered."); // 處理行結(jié)束符 break; case StreamTokenizer.TT_EOF: // EOF 不需要處理 break; default: System.out.println("Other: " + (char) tokenizer.ttype); // 處理其他字符 break; } } catch (IOException e) { // 統(tǒng)一拋出異常 throw new RuntimeException("Error processing the token", e); } } }
總結(jié)
Scanner
適用于簡單、格式規(guī)范的輸入,尤其是在處理基本數(shù)據(jù)類型時非常方便。其優(yōu)勢在于靈活性,但性能較BufferedReader
差。BufferedReader
適用于處理大塊文本輸入,特別是在處理文件數(shù)據(jù)時。通過緩沖機制,BufferedReader
提供了較高的性能。StreamTokenizer
適用于復(fù)雜的文本解析,能夠根據(jù)不同的詞法規(guī)則分割輸入流,并且能夠靈活地處理各種標記。
到此這篇關(guān)于Java中的Scanner、BufferedReader 和 StreamTokenizer的文章就介紹到這了,更多相關(guān)Java Scanner、BufferedReader 和 StreamTokenizer內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java實現(xiàn)正則匹配 “1234567” 這個字符串出現(xiàn)四次或四次以上
文章介紹了如何在Java中使用正則表達式匹配一個字符串四次或四次以上的出現(xiàn),首先創(chuàng)建正則表達式,然后使用Pattern和Matcher類進行匹配和計數(shù),通過示例代碼展示了如何實現(xiàn)這一功能,并解釋了匹配的整體次數(shù)和精確出現(xiàn)次數(shù)的邏輯,感興趣的朋友一起看看吧2025-02-02SpringBoot通過@Value實現(xiàn)給靜態(tài)變量注入值詳解
這篇文章主要介紹了springboot如何通過@Value給靜態(tài)變量注入值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07java如何在項目中實現(xiàn)excel導(dǎo)入導(dǎo)出功能
這篇文章主要介紹了java如何在項目中實現(xiàn)excel導(dǎo)入導(dǎo)出功能的相關(guān)資料,EasyExcel是一個基于Apache?POI開發(fā)的開源Java庫,用于簡化Excel文件的讀寫操作,文中將用法介紹的非常詳細,需要的朋友可以參考下2024-10-10SpringBoot DBUnit 單元測試(小結(jié))
這篇文章主要介紹了SpringBoot DBUnit 單元測試(小結(jié)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09