当前位置: 首页 > article >正文

Golang|单例模式

  • 单例模式定义:在程序运行期间,某个结构体只创建一个实例。
  • 适用场景:如数据库连接池,在整个程序运行期间只需要一个连接池实例。
  1. 方案一:通过加锁的方式,如读写锁,确保在并发情况下只创建一个实例。
  2. 方案二:使用unit函数,适用于简单的全局变量初始化,但需注意依赖问题。
  3. 方案三:使用once函数,确保在程序运行期间只执行一次初始化操作。
package testsimport ("fmt""gorm.io/driver/mysql""gorm.io/gorm""sync"
)var single *gorm.DB // 通过gorm.Open()创建的gorm.DB是一个连接池,只需要创建它的一个实例
var once = sync.Once{}
var lock = &sync.Mutex{}func GetDB1() *gorm.DB {if single == nil { //先判断是否为nil,避免无谓的上锁lock.Lock()defer lock.Unlock()if single == nil { //需要二次确认实例尚未创建。如果用sync.Once就不用二次确认single, _ = gorm.Open(mysql.Open(""))} else {fmt.Println("单例已经创建过了")}} else {fmt.Println("单例已经创建过了")}return single
}//func init() { //init()只会执行一次,所以可以实现单例。但使用init()通常要小心代码的各种依赖关系,关心代码的执行顺序
//	single, _ = gorm.Open(mysql.Open(""))
//}
//
//func GetDB2() *gorm.DB {
//	return single
//}func GetDB3() *gorm.DB {if single == nil { //先判断是否为nil,避免无谓的once.Doonce.Do(func() {single, _ = gorm.Open(mysql.Open(""))})} else {fmt.Println("单例已经创建过了")}return single
}
http://www.lryc.cn/news/2392563.html

相关文章:

  • 哈尔滨工业大学计算机系统大作业程序人生-Hello’s P2P
  • 小程序定制开发:从需求到落地,打造企业专属数字化入口
  • 【C/C++】基于 Docker 容器运行的 Kafka + C++ 练手项目
  • Linux系统管理与编程24:基础条件准备-混搭“本地+阿里云”yum源
  • 新一代Python管理UV完全使用指南|附实际体验与效果对比
  • 如何在 Windows 10 PC 上获取 iPhone短信
  • STM32程序运行不了,仿真功能也异常,连断点和复位都异常了
  • Linux 系统中的软链接与硬链接
  • Python爬虫第22节- 结合Selenium识别滑动验证码实战
  • 【C/C++】chrono简单使用场景
  • Escrcpy(安卓手机投屏软件) v1.29.6 中文绿色版
  • Oracle MOVE ONLINE 实现原理
  • Linux:深入理解网络层
  • 【设计模式】简单工厂模式,工厂模式,抽象工厂模式,单例,代理,go案例区分总结
  • Linux_编辑器Vim基本使用
  • vue展示修改前后对比,并显示修改标注diff
  • LiveWallpaperMacOS:让你的 Mac 桌面动起来
  • [预训练]Encoder-only架构的预训练任务核心机制
  • 07-后端Web实战(部门管理)
  • mysql ACID 原理
  • [Rust_1] 环境配置 | vs golang | 程序运行 | 包管理
  • 二十五、面向对象底层逻辑-SpringMVC九大组件之HandlerMapping接口设计
  • 构建安全高效的邮件网关ngx_mail_ssl_module
  • HUAWEI交换机配置镜像口验证(eNSP)
  • 前端vue3实现图片懒加载
  • 网站每天几点更新,更新频率是否影响网站收录
  • 主流Markdown编辑器的综合评测与推荐
  • 计算机网络-MPLS VPN应用场景与组网
  • AugmentFree:解除 AugmentCode 限制的终极方案 如何快速清理vscode和AugmentCode缓存—windows端
  • WPF【11_7】WPF实战-重构与美化(ViewModel的嵌套与分解、海量数据不要Join)