」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 案例研究:計算關鍵字

案例研究:計算關鍵字

發佈於2024-07-31
瀏覽:879

Case Study: Counting Keywords

本節介紹一個計算 Java 原始檔中關鍵字數量的應用程式。對於Java來源檔案中的每個單字,我們需要判斷該單字是否為關鍵字。為了有效地處理這個問題,請將所有關鍵字儲存在 HashSet 中,並使用 contains 方法來測試某個單字是否在關鍵字集中。下面的程式碼給出了這個程式。

package demo;
import java.util.*;
import java.io.*;

public class CountKeywords {

    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        System.out.print("Enter a Java source file: ");
        String filename = input.nextLine();

        File file = new File(filename);
        if(file.exists()) {
            try {
                System.out.println("The number of keywords in "   filename   " is "   countKeywords(file));
            } catch (Exception e) {
                System.out.println("An error occurred while counting keywords: "   e.getMessage());
            }
        } else {
            System.out.println("File "   filename   " does not exist");
        }
    }

    public static int countKeywords(File file) throws Exception {
        // Array of all Java keywords   true, false and null
        String[] keywordString = {"abstract", "assert", "boolean", "break", "byte", "case", "catch", "char", "class", "const", "continue", "default", "do", "double", "else", "enum", "extends", "for", "final", "finally", "float", "goto", "if", "implements", "import", "instanceof", "int", "interface", "long", "native", "new", "package", "private", "protected", "public", "return", "short", "static", "strictfp", "super", "switch", "synchronized", "this", "throw", "throws", "transient", "try", "void", "volatile", "while", "true", "false", "null"};

        Set keywordSet = new HashSet(Arrays.asList(keywordString));
        int count = 0;

        Scanner input = new Scanner(file);

        while(input.hasNext()) {
            String word = input.next();
            if(keywordSet.contains(word))
                count  ;
        }

        return count;
    }

}

輸入Java原始檔:c:\Welcome.java
c:\Welcome.java中的關鍵字數量為5

輸入Java原始檔:c:\TTT.java
文件 c:\TTT.java 不存在

程式提示使用者輸入 Java 原始檔名(第 9 行)並讀取檔名(第 10 行)。如果檔案存在,則呼叫 countKeywords 方法統計檔案中的關鍵字(第 15 行)。

countKeywords 方法為關鍵字建立字串陣列(第 26 行),並根據該陣列建立一個哈希集(第 28 行)。然後它從檔案中讀取每個單字並測試該單字是否在集合中(第 35 行)。如果是,程式將計數加 1(第 36 行)。

您可以重寫程式以使用LinkedHashSetTreeSetArrayListLinkedList來儲存關鍵字。然而,使用 HashSet 對這個程式來說是最有效的。

版本聲明 本文轉載於:https://dev.to/paulike/case-study-counting-keywords-4kfa?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3