> 백엔드 개발 > Golang > 쓰기 후 Go *os.File 포인터에서 읽으면 예기치 않은 EOF가 발생하는 이유는 무엇입니까?

쓰기 후 Go *os.File 포인터에서 읽으면 예기치 않은 EOF가 발생하는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-23 14:05:17
원래의
890명이 탐색했습니다.

Why Does Reading from a Go *os.File Pointer After Writing Result in Unexpected EOF?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿