Go에서 동일한 *os.File 포인터로 작성한 후 파일 읽기
Go에서는 생성, 쓰기가 가능합니다. , *os.File 포인터를 사용하여 파일을 읽습니다. 그러나 동일한 파일 포인터에 쓴 후 데이터를 읽으면 예기치 않은 동작이 발생할 수 있습니다.
문제:
다음 코드 조각을 고려하세요.
package main import ( "bufio" "fmt" "io" "os" ) func main() { filename := "test.txt" f, _ := os.OpenFile(filename, os.O_CREATE|os.O_TRUNC|os.O_RDWR, os.ModePerm) defer os.Remove(filename) // Write 10 times for i := 0; i< 10; i++ { fmt.Fprintf(f, "test%d\n", i) } // Read 10 times r := bufio.NewReader(f) for i := 0; i < 10; i++ { str, _, err := r.ReadLine() if err != nil { if err == io.EOF { fmt.Println("Done") return } fmt.Println("Error", err) } fmt.Println("Read", string(str)) } }
이 코드에서는 파일을 생성하고 fmt.Fprintf 함수를 사용하여 파일에 10줄을 씁니다. 그런 다음 bufio.NewReader를 사용하여 동일한 파일 포인터에서 10줄을 읽으려고 시도합니다. 그러나 코드는 항상 파일 끝에 도달했음을 나타내는 "완료"를 인쇄합니다.
해결책:
이 문제는 데이터가 다음에 기록될 때 발생합니다. *os.File인 경우 파일 포인터가 파일 끝으로 이동됩니다. 결과적으로 파일에서 읽으려고 하면 파일 끝에서 시작하고 즉시 파일 끝 표시기를 만나게 됩니다.
이 문제를 해결하려면 파일 포인터를 파일을 읽으려고 시도하기 전에 파일의 시작 부분을 삭제합니다. 이는 Seek 기능을 사용하여 달성할 수 있습니다.
_, err := f.Seek(0, 0) if err != nil { fmt.Println("Error", err) }
파일에 쓴 후 이 줄을 추가하면 읽기 시작할 때 파일 포인터가 파일의 시작 부분에 있는지 확인하여 성공적으로 작업할 수 있습니다. 작성된 데이터를 읽어보세요.
위 내용은 쓰기 후 Go *os.File 포인터에서 읽으면 예기치 않은 EOF가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!