Golang设计模式之单例模式

1. 概述

单例模式,顾名思义就是在程序的运行中只产生一个实力。在Go实现上也有多种形式。

相关源代码demo在Github上,可供参考!

2. 实现

一、懒汉模式.

这种方式实现起来特别简单,直接判断一个实力是不是为nil, 如果是,则新生成;否则返回已有的。但它和多数语言一样,只适合用在单线程。

@H_403_16@type SingleTon struct { }

var @H_403_16@instance *SingleTon

func GetInstance() *SingleTon {
    @H_403_16@if Instance == nil {
 @H_403_16@instance = &SingleTon{} } return @H_403_16@instance }

二、使用加锁机制

在Go语言中有个基础对象sync.Mutex,可以实现协程之间的同步逻辑。

@H_403_16@var mu sync.Mutex

@H_403_16@func GetInstance() *SingleTon {
  mu.Lock()
  @H_403_16@defer mu.Unock()

    @H_403_16@if Instance == nil {
        instance = &SingleTon{}
    }

    @H_403_16@return instance
}

三、 sync.Once用法

在Go中还有一个更简洁的方法就是使用sync.Once,它可以在多协程中起到控制作用。实现起来也非常简单。

var (
    once     sync.Once
 @H_403_16@instance *SingleTon ) func GetInstance(str string) *SingleTon { once.Do(func() { @H_403_16@instance = &SingleTon{Attr: str} }) return @H_403_16@instance }

测试代码如下,从运行结果来看,都是一致的。

@H_403_16@func main() {
    @H_403_16@for i := 0; i < 10; i++ {
        @H_403_16@go @H_403_16@func() {
            s := GetInstance("test:" + strconv.Itoa(i))
            s.TestFunc()
        }()
    }
    time.Sleep(1e5)
}

相关文章

程序目录结构 简单实现,用户登录后返回一个jwt的token,下次请求带上token请求用户信息接口并返回信息...
本篇博客的主要内容是用go写一个简单的Proof-of-Work共识机制,不涉及到网络通信环节,只是一个本地的简...
简介 默克尔树(MerkleTree)是一种典型的二叉树结构,其主要特点为: 最下面的叶节点包含存储数据或其...
接下来学习并发编程, 并发编程是go语言最有特色的地方, go对并发编程是原生支持. goroutine是go中最近本...
先普及一下, 什么是广度优先搜索 广度优先搜索类似于树的层次遍历。从图中的某一顶点出发,遍历每一个顶...
第一天: 接口的定义和实现 第二天: 一. go语言是面向接口编程. 在学习继承的时候说过, go语言只有封装,...