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条)

报告相同问题?