dongzhuan1185 2018-07-21 16:10
浏览 4

Golang中的记录器功能失败

I have what should be a very simple logger function but while the log file is created, nothing is written to it. I tried several different things but it continues to fail. The function is

func logger(logname string, message string) {
    logName := "../planner/log/" + logname + ".log"
    var file *os.File

    file, err := os.OpenFile(logName, os.O_APPEND|os.O_CREATE, 0755)
    if err != nil {
        fmt.Println("File", logName, "failed with error:", err)
    }

    //file.WriteString(message)
    fmt.Fprintf(file, message)
    fmt.Println("Wrote", message, "to", logName)
    file.Sync()
    file.Close()

    test, err := os.Stat(logName)
    size := test.Size()
    fmt.Println("File size is", size)
}
  • 写回答

1条回答 默认 最新

  • dongxie559554 2018-07-24 08:24
    关注

    You are not getting anything in file because you are not opening it with os.WRONLY or os.RDWR. By default. os.OpenFile returns a buffer with only read permission. You might want to close your file with a defer in case the code panics with defer file.Close().

    评论

报告相同问题?

悬赏问题

  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥30 BC260Y用MQTT向阿里云发布主题消息一直错误
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据
  • ¥15 Vue3 大型图片数据拖动排序
  • ¥15 Centos / PETGEM
  • ¥15 划分vlan后不通了
  • ¥20 用雷电模拟器安装百达屋apk一直闪退
  • ¥15 算能科技20240506咨询(拒绝大模型回答)