douzi1117 2014-05-09 23:55
浏览 94
已采纳

软件包依赖关系和初始化

I'm new to Go and trying to find a solution to the following problem.

  1. The goal is to write all logs to a file.
  2. package main imports package A.
  3. In package main, in the main method, logging is setup to write to a file
  4. package A has an init function. In the init function of A, there is a log line - log.Fatal("I am package A").
  5. Since main package imports A, A's init function is first called (even before we get a chance to setup the logs to write to a file).

How to resolve this so the log "I am package A" gets written to a file?

  • 写回答

2条回答 默认 最新

  • douhuan1979 2014-05-10 00:13
    关注

    Move logging initialization out to a log package that is imported by both main and A and does not depend directly or indirectly on the parts of your app that you want to log to the file during initialization. From the descriptions of init order in Effective Go and the spec, that should be enough to make sure your logging is initialized first thing.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵
  • ¥15 cfx离心泵非稳态计算