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

Java中的Scanner、BufferedReader?和?StreamTokenizer使用詳解

 更新時間:2025年02月05日 08:46:29   作者:nmblr  
Scanner是Java?中一個用于解析原始類型(如?int、double?等)和字符串的類,它通常從輸入流中逐個讀取數(shù)據(jù)并進行解析,支持多種分隔符的使用,本文介紹Java中的Scanner、BufferedReader?和?StreamTokenizer的相關(guān)知識,感興趣的朋友一起看看吧

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)正則匹配 “1234567” 這個字符串出現(xiàn)四次或四次以上

    文章介紹了如何在Java中使用正則表達式匹配一個字符串四次或四次以上的出現(xiàn),首先創(chuàng)建正則表達式,然后使用Pattern和Matcher類進行匹配和計數(shù),通過示例代碼展示了如何實現(xiàn)這一功能,并解釋了匹配的整體次數(shù)和精確出現(xiàn)次數(shù)的邏輯,感興趣的朋友一起看看吧
    2025-02-02
  • Java多線程用法的實例詳解

    Java多線程用法的實例詳解

    這篇文章主要介紹了Java多線程用法的實例詳解的相關(guān)資料,希望通過本文大家能夠理解掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-09-09
  • SpringBoot通過@Value實現(xiàn)給靜態(tài)變量注入值詳解

    SpringBoot通過@Value實現(xiàn)給靜態(tài)變量注入值詳解

    這篇文章主要介紹了springboot如何通過@Value給靜態(tài)變量注入值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 如何實現(xiàn)bean初始化摧毀方法的注入

    如何實現(xiàn)bean初始化摧毀方法的注入

    這篇文章主要為大家介紹了如何實現(xiàn)bean初始化摧毀方法的注入詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • Java8 Lambda表達式模板方法實現(xiàn)解析

    Java8 Lambda表達式模板方法實現(xiàn)解析

    這篇文章主要介紹了Java8 Lambda表達式模板方法實現(xiàn)解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • java如何在項目中實現(xiàn)excel導(dǎo)入導(dǎo)出功能

    java如何在項目中實現(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-10
  • 沒有外網(wǎng)IDEA離線使用maven倉庫的方法

    沒有外網(wǎng)IDEA離線使用maven倉庫的方法

    這篇文章主要介紹了沒有外網(wǎng),IDEA如何離線使用maven倉庫,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • SpringBoot DBUnit 單元測試(小結(jié))

    SpringBoot DBUnit 單元測試(小結(jié))

    這篇文章主要介紹了SpringBoot DBUnit 單元測試(小結(jié)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • Java線程取消的三種方式

    Java線程取消的三種方式

    文章介紹了 Java 線程取消的 3 種方式,不推薦使用 stop 方法和 volatile 設(shè)標記位停止線程,線程中斷機制是協(xié)作式的,一個線程請求中斷,另一線程響應(yīng),線程可檢查自身中斷狀態(tài)或捕獲 InterruptedException 來合適處理以響應(yīng)中斷,確保安全有序停止,避免資源泄露等問題
    2024-12-12
  • 通Java接口上傳實現(xiàn)SMMS圖床

    通Java接口上傳實現(xiàn)SMMS圖床

    這篇文章主要介紹了通Java接口上傳實現(xiàn)SMMS圖床,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07

最新評論