欢迎光临
我们一直在努力

包中带有单例的设计模式

包中带有单例的设计模式

php小编苹果在这里给大家介绍一种常用的设计模式——带有单例的设计模式。在软件开发中,单例模式被广泛应用,它可以确保一个类只有一个实例,并提供一个全局访问点。这种设计模式可以提高代码的复用性和性能,同时也能够避免一些潜在的问题。在使用这种设计模式时,需要注意线程安全性和懒加载等细节问题,以确保实现的正确性和可靠性。

问题内容

我仍然不是 golang 专家,并尝试理解和学习最佳实践

如何在包中初始化单例并使其线程安全,这样即使在不同文件中多次导入包,也只会有一个实例

现在实例 sessions 在 main 中启动,但随后我必须传递它。如何在 sess 包内启动实例 sessions ,使其成为全局变量或包内的其他内容?

我希望它是 sess 包内的私有变量

package main

func main(){
    sessions := sess.Init()
}

sess模块

package sess

import (
    "sync"
    "time"
)

type pool struct {
    lock        sync.RWMutex
    sessions    map[string]*session
}

func Init() *pool {
    p := &pool{
        sessions:   map[string]*session{},
    }
        
    return p
}

func (p *pool) Set(sid string, s *session){
    p.lock.Lock()
    defer p.lock.Unlock()
    
    p.sessions[sid] = s
}

func (p *pool) Get(sid string) (*session, bool){
    p.lock.RLock()
    defer p.lock.RUnlock()
    
    s, ok := p.sessions[sid]
    return s, ok
}

解决方法

使用单例声明并初始化导出的包级变量。每个包级变量都有一个初始化实例,而不是每次导入都有一个实例或初始化。

package sess

import (
    "sync"
    "time"
)

type pool struct {
    lock        sync.RWMutex
    sessions    map[string]*session
}

var Pool = &pool{sessions: map[string]*session{}}

func (p *pool) Set(sid string, s *session){
    p.lock.Lock()
    defer p.lock.Unlock()
    
    p.sessions[sid] = s
}

func (p *pool) Get(sid string) (*session, bool){
    p.lock.RLock()
    defer p.lock.RUnlock()
    
    s, ok := p.sessions[sid]
    return s, ok
}
赞(0) 打赏
未经允许不得转载:码农资源网 » 包中带有单例的设计模式
分享到

觉得文章有用就打赏一下文章作者

非常感谢你的打赏,我们将继续提供更多优质内容,让我们一起创建更加美好的网络世界!

支付宝扫一扫打赏

微信扫一扫打赏

登录

找回密码

注册