golang设计模式--单例模式

本文深入探讨Golang中单例模式的实现方法,包括懒汉式、饿汉式、加锁懒汉式、双重检查锁定及sync.Once的使用。分析每种方式的优缺点,帮助读者理解并正确应用单例模式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

golang单例模式

 

1、定义:单例对象的类必须保证只有一个实例存在,全局有唯一接口访问。

2、分类:  

  • 懒汉方式:指全局的单例实例在第一次被使用时构建。
  • 饿汉方式:指全局的单例实例在类装载时构建。

3、实现:

 (1)懒汉方式  

 type singleton struct{}
 var ins *singleton
 func GetIns() *singleton{
     if ins == nil {
       ins = &singleton{}
     }
     return ins
}

  缺点:非线程安全。当正在创建时,有线程来访问此时ins = nil就会再创建,单例类就会有多个实例了。

(2)饿汉方式

  

 type singleton struct{}
 var ins *singleton = &singleton{}
 func GetIns() *singleton{
     return ins
 }

  缺点:如果singleton创建初始化比较复杂耗时时,加载时间会延长。

(3)懒汉加锁

  

  type singleton struct{}
  var ins *singleton
  var mu sync.Mutex
  func GetIns() *singleton{
      mu.Lock()
      defer mu.Unlock()
  
      if ins == nil {
        ins = &singleton{}
     }
     return ins
 }

  缺点:虽然解决并发的问题,但每次加锁是要付出代价的

(4)双重锁

   type singleton struct{}
   var ins *singleton
   var mu sync.Mutex
   func GetIns() *singleton{  
     if ins == nil {
        mu.Lock()
         defer mu.Unlock()
         if ins == nil {
          ins = &singleton{}
        }
     }
     return ins
 }

  避免了每次加锁,提高代码效率

(5)sync.Once实现

 type singleton struct{}
 var ins *singleton
 var once sync.Once
 func GetIns() *singleton {
     once.Do(func(){
         ins = &singleton{}
     })
     return ins
 }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值