이 섹션에서는 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"}; SetkeywordSet = 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를 사용하는 것이 가장 효율적입니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3