【问题标题】:I get an error that I don't know for what reason. a file disappears when I run the program我收到一个我不知道是什么原因的错误。运行程序时文件消失
【发布时间】:2021-04-08 16:13:51
【问题描述】:

我正在使用 Go 进行编码,并创建了一个文件处理程序和一个打印该文件值的程序。

但是,当我运行它时,应该使用 file.Filename 创建的文件被删除。

不知道是什么原因,即使我尝试调试,也没有答案,即使我google了,我也没有得到答案。

(64 位 windows 10 (WSL2))

package main

import (
    "fmt"
    "io"
    "io/ioutil"
    "os"

    "github.com/labstack/echo"
)

func checkErr(err error) {
    if err != nil {
        panic(err)
    }
}

func readFile(filename string) string {
    data, err := ioutil.ReadFile(filename)
    checkErr(err)
    return string(data)
}

func main() {
    e := echo.New()

    e.POST("/file", func(c echo.Context) error {
        file, err := c.FormFile("file")
        checkErr(err)

        src, err := file.Open()
        checkErr(err)
        defer src.Close()

        dst, err := os.Create(file.Filename)
        checkErr(err)
        defer dst.Close()

        _, err = io.Copy(dst, src)
        checkErr(err)

        data := readFile(file.Filename)

        fmt.Println(data)

        return c.String(200, "sd")
    })

    e.Logger.Fatal(e.Start(":5000"))
}

【问题讨论】:

  • 是文件被删除还是文件为空?
  • 在重新阅读之前尝试syncing文件。

标签: file go operating-system go-echo


【解决方案1】:

我猜你的文件是存在的,但是你写的代码是在更改之前读取文件的"flushed to disk"

就在这里:

defer dst.Close()
 _, err = io.Copy(dst, src)

应该尽快Close()Sync()你的作者,否则你可能会在写完之前阅读。而且由于您的 readFile() 函数没有重复使用该文件,因此您最好立即关闭(而不是 Sync())它,而不是延迟

试试这个:

 _, err = io.Copy(dst, src)
dst.Close()
if err != nil {
  
}

复制时可能会出错,但我们仍然希望 Close() 文件(如果在 os.Create os.Open,os.OpenFile 期间没有错误...

【讨论】:

  • 在我看来您首先关闭文件,然后再复制,否则您会遇到竞争条件。
  • 是的。这正是发生的事情
猜你喜欢
  • 1970-01-01
  • 2018-04-12
  • 1970-01-01
  • 2020-08-13
  • 1970-01-01
  • 1970-01-01
  • 2015-03-24
  • 1970-01-01
  • 2022-08-24
相关资源
最近更新 更多