대규모 디렉토리의 효율적인 파일 목록
많은 수의 파일이 있는 디렉토리를 프로그래밍 방식으로 탐색하면 성능 문제가 발생할 수 있습니다. 이러한 제한을 극복하려면 Go의 기본 디렉토리 읽기 메커니즘을 이해하는 것이 중요합니다.
Readdirnames 방지
filepath.Walk를 사용하는 기존 접근 방식은 ioutil에 의존합니다. 파일 조각을 반환하는 ReadDir 및 filepath.Glob 함수. 그러나 이러한 함수는 지나치게 큰 디렉터리를 처리할 때 메모리 제한으로 인해 어려움을 겪습니다.
버퍼 배열에서 작동하는 ReadDirnames를 사용하는 대신 하위 수준 Readdir 또는 Readdirnames 메서드를 직접 고려하세요. 이러한 방법을 사용하면 0보다 큰 배치 크기(n)를 지정할 수 있으므로 디렉토리 항목을 배치로 검색할 수 있습니다.
샘플 코드
다음 코드 조각 Readdir을 사용하여 디렉터리 항목을 읽는 방법을 보여줍니다.
<code class="go">package main import ( "fmt" "io/ioutil" "os" ) func main() { files, err := ioutil.ReadDir("directory_path") if err != nil { fmt.Println(err) return } for _, file := range files { fmt.Println(file.Name()) } }</code>
충분한 배치 크기(예: 10000)를 지정하면 메모리 문제 없이 대규모 디렉터리 목록을 효율적으로 처리할 수 있습니다.
위 내용은 ## Go를 사용하여 대용량 디렉터리의 파일을 효율적으로 나열하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!