登录
首页 >  Golang >  Go问答

消灭全局变量的步骤

来源:stackoverflow

时间:2024-03-13 17:51:31 331浏览 收藏

从现在开始,我们要努力学习啦!今天我给大家带来《消灭全局变量的步骤》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!

问题内容

我刚刚开始学习 go,到处都提到建议最佳实践避免使用全局变量。我有这段代码:

package main

const scriptVersion = "1.1"
var debug = 0

func logHandler(t, e string) {
    switch t {
    case "warning":
        fmt.Println("WARNING |", e)
    case "error":
        fmt.Println("ERROR   |", e)
        os.Exit("1")
    case "debug":
        if debug == 1 {
            fmt.Println("DEBUG   |", e)
        }
    default:
        fmt.Println("INFO    |", e)
    }
}

for userOptsValue := range os.Args { {
        switch userOptsValue {
        case "-d", "--debug":
            d := &debug
            *d = 1
            logHandler("debug", "Debug Enabled")
        case "-v", "--version":
            logHandler("info", "Version "+scriptVersion)
        default:
            logHandler("warning", "Unknown Option "+userOptsValue+","+" ignoring")
        }
    }

这个想法是通过使用 -d 或 --debug 参数调用脚本来激活脚本中的调试操作。我怎样才能做同样的事情但避免全局变量“var debug = 0”?


解决方案


如果调试标志仅影响您的日志记录,请创建一个

type logger struct {
    debug bool
}

捕获该状态,然后使您的 loghandler 成为该类型的方法 log(...)

这就留下了在哪里创建 logger 实例的问题。在日志记录的具体情况下,它在整个程序中经常无处不在,我可以想到两种可能性:

1) 使用全局日志变量/函数,即在程序开头创建一个 logger,然后在全局范围内到处使用它。这意味着您可以将其放入您自己的 log 包中,例如内置的 package log(顺便说一下,您也可以使用它,但我发现您经常需要其他东西来进行日志记录)。

2) 同样,拥有一个 logger 实例,但不要使其全局可用,而是将其传递到您需要使用它的所有位置。在主模块中创建它并将其传递给需要使用它的子模块。这高度依赖于您的代码组织,有时很容易做到这一点,有时则不然。在某些情况下,选项 1) 可能更适合您。

好了,本文到此结束,带大家了解了《消灭全局变量的步骤》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

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