이 섹션에서는 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<String> 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행).
LinkedHashSet, TreeSet, ArrayList 또는 LinkedList를 사용하여 키워드를 저장하도록 프로그램을 다시 작성할 수 있습니다. 하지만 이 프로그램에서는 HashSet을 사용하는 것이 가장 효율적입니다.
위 내용은 사례 연구: 키워드 계산의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!