登录
首页 >  Golang >  Go问答

Golang中是否鼓励创建全局变量并将其用于良好实践?

来源:stackoverflow

时间:2024-02-13 22:54:22 121浏览 收藏

有志者,事竟成!如果你在学习Golang,那么本文《Golang中是否鼓励创建全局变量并将其用于良好实践?》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

问题内容

所以我正在创建一个 cli 应用程序,一些命令需要访问数据库。 现在他们都得到了这个代码:

db, err := gorm.Open(sqlite.Open(fmt.Sprintf("%s/db/db.sqlite", dir)), &gorm.Config{})
        if err != nil {
            panic("failed to connect database")
        }

这违反了 dry 原则(不要重复自己)。

有办法避免这种情况吗?


正确答案


我认为这大致就是 @flimzy 在谈论依赖注入时所想到的(告诉我我是否错了!)

The entire self-contained example is herecommands 结构体中有一个指向数据库的指针。该结构上的任何方法都可以访问此打开的数据库。

type commands struct {
    db *gorm.db
}

// an example command
func (c commands) findbyuuid() (m []mymodel, err error) {
    // the commands now have access to the database
    c.db.find(&m, "tag = ?", "foobar")
    return m, c.db.error
}

或者将其作为显式参数传递:

func FindByUUID(db *gorm.DB) (m []MyModel, err error) {
    db.Find(&m, "tag = ?", "foobar")
    return m, db.Error
}

终于介绍完啦!小伙伴们,这篇关于《Golang中是否鼓励创建全局变量并将其用于良好实践?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

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