Java 파일의 줄 수를 효율적으로 결정하는 방법
파일의 줄 수를 세는 것은 프로그래밍에서 일반적인 작업입니다. . Java에서 일반적인 접근 방식 중 하나는 파일을 끝까지 읽을 때까지 한 줄씩 읽는 것인데, 이는 대용량 파일의 경우 비효율적일 수 있습니다.
더 최적화된 솔루션은 파일을 바이트 단위로 읽는 countLinesOld 메서드를 사용하는 것입니다. byte이고 개행 문자(n)의 발생 횟수를 셉니다. 이 접근 방식은 특히 대용량 파일의 경우 파일을 한 줄씩 읽는 것보다 훨씬 빠릅니다.
public static int countLinesOld(String filename) throws IOException { InputStream is = new BufferedInputStream(new FileInputStream(filename)); try { byte[] c = new byte[1024]; int count = 0; int readChars = 0; boolean empty = true; while ((readChars = is.read(c)) != -1) { empty = false; for (int i = 0; i < readChars; ++i) { if (c[i] == '\n') { ++count; } } } return (count == 0 && !empty) ? 1 : count; } finally { is.close(); } }
그러나 더 빠른 성능을 위해서는 루프 풀기 및 캐싱과 같은 최적화를 활용하는 countLinesNew 메서드를 사용하는 것이 좋습니다. 파일의 각 1024바이트 청크에 대한 줄 수입니다.
public static int countLinesNew(String filename) throws IOException { InputStream is = new BufferedInputStream(new FileInputStream(filename)); try { byte[] c = new byte[1024]; int readChars = is.read(c); if (readChars == -1) { // bail out if nothing to read return 0; } // make it easy for the optimizer to tune this loop int count = 0; while (readChars == 1024) { for (int i=0; i<1024;) { if (c[i++] == '\n') { ++count; } } readChars = is.read(c); } // count remaining characters while (readChars != -1) { for (int i=0; i<readChars; ++i) { if (c[i] == '\n') { ++count; } } readChars = is.read(c); } return count == 0 ? 1 : count; } finally { is.close(); } }
이러한 최적화된 방법은 표준 readLines에 비해 상당한 속도 향상을 제공합니다. 접근 방식을 사용하므로 대용량 파일의 줄을 효율적으로 계산하는 데 이상적입니다.
위 내용은 Java 파일의 줄 수를 계산하는 가장 효율적인 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!