Skip to content

Files

Latest commit

 

History

History
60 lines (39 loc) · 1.86 KB

File metadata and controls

60 lines (39 loc) · 1.86 KB

单例模式

5.1. 模式动机

对于系统中的某些类来说,只有一个实例很重要,例如,一个系统中可以存在多个打印任务,但是只能有一个正在工作的任务;一个系统只能有一个窗口管理器或文件系统;一个系统只能有一个计时工具或ID(序号)生成器。

如何保证一个类只有一个实例并且这个实例易于被访问呢?定义一个全局变量可以确保对象随时都可以被访问,但不能防止我们实例化多个对象。

一个更好的解决办法是让类自身负责保存它的唯一实例。这个类可以保证没有其他实例被创建,并且它可以提供一个访问该实例的方法。这就是单例模式的模式动机。

5.2. 模式定义

单例模式(Singleton Pattern):单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例,这个类称为单例类,它提供全局访问的方法。

单例模式的要点有三个:一是某个类只能有一个实例;二是它必须自行创建这个实例;三是它必须自行向整个系统提供这个实例。单例模式是一种对象创建型模式。单例模式又名单件模式或单态模式。

5.3. 模式结构

单例模式包含如下角色:

  • Singleton:单例

../_images/Singleton.jpg

5.4. 代码分析

package singleton

import "sync"

//Singleton 是单例模式类
type Singleton struct{}

var singleton *Singleton
var once sync.Once

//GetInstance 用于获取单例模式对象
func GetInstance() *Singleton {
   once.Do(func() {
      singleton = &Singleton{}
   })

   return singleton
}
package singleton

import "testing"

func TestSingleton(t *testing.T) {
   ins1 := GetInstance()
   ins2 := GetInstance()
   if ins1 != ins2 {
      t.Fatal("instance is not equal")
   }
}