登录
首页 >  Golang >  Go问答

父包全局引用内部包全局初始化?

来源:stackoverflow

时间:2024-03-11 17:00:27 134浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《父包全局引用内部包全局初始化?》,聊聊,我们一起来看看吧!

问题内容

我试图在内部包中使用父包中定义的全局变量。没有错误,但没有打印内部包中的任何日志。我对 init 顺序的假设是:parent.go 全局变量,然后是内部包中的 init() ;用 fmt.println() 测试时这似乎是正确的。但看起来对 replaceglobals 的调用在编译期间被删除。有没有办法修复它,以便我可以使用内部包中的全局变量?

这是我正在使用的 zap 包:zap。这里讨论了有问题的 api。这是代码片段。

~/parent/parent.go

package main

import (
    "log"

    "go.uber.org/zap"
    "parent/internal"
)

var (
    logger = getmylogger()
    undo   = zap.replaceglobals(logger.desugar())
)

func getmylogger() *zap.sugaredlogger {
    xx, err := zap.newproduction()
    if err != nil {
        log.fatal("error")
    }
    sugar := xx.sugar()
    return sugar
}

func main() {
    logger.infof("logger in main")
    internal.new()
}

然后在~/parent/internal/internal.go

package internal

import (
    "go.uber.org/zap"
)

var logger *zap.SugaredLogger

func init() {
    logger = zap.L().Sugar()
    logger.Infof("init() from internal: %v\n", logger)

    logger = zap.S()
    logger.Infof("init() from internal: %v\n", logger)
}

func New() {
    logger.Infof("New() from internal")
}

解决方案


包初始化顺序已明确定义,请参阅 Spec: Package initialization。基本上,您可以确定,如果您引用一个包,则该包的初始化将首先递归地完成。

由于您的 internal 包不引用您的 main,因此您无法保证 main 在从 internal 执行任何操作之前是否已初始化。

针对您的情况,一个简单的解决方案是将记录器移动到您的 internal 包,并让 main 引用/使用它。

如果您涉及更多包,并且您想使用其他包中的相同记录器,您可能有一个指定的包来保存记录器,并让每个人参考/使用它。

今天关于《父包全局引用内部包全局初始化?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>