0

0

如何在Go中避免过度设计模式_Go设计模式合理使用建议

P粉602998670

P粉602998670

发布时间:2026-02-09 12:53:02

|

174人浏览过

|

来源于php中文网

原创

单例应使用sync.Once而非手写双重检查锁;工厂即New函数,参数用Option封装、返回接口、显式处理error;装饰器用func(http.Handler) http.Handler闭包实现;接口应小而专注,按调用方需求定义。

如何在go中避免过度设计模式_go设计模式合理使用建议

什么时候该用单例?别手写双重检查锁

Go里单例就一个正解:sync.Once。自己写mutex加锁做双重检查,不仅性能差,还容易漏掉读锁或初始化竞态——比如instance提前赋值,协程可能读到零值结构体。
必须把初始化逻辑全塞进once.Do()的闭包里,返回*Config这类指针,别返回值类型(会破坏单例语义)。
常见错误:在GetInstance()里对返回值深拷贝或加读锁——没必要,线程安全只管初始化,后续访问由使用者自己保障。

工厂模式不是“模式”,是Go构造函数惯用法

Go没有抽象工厂、工厂方法那一套接口抽象,日常开发中所谓“工厂”就是NewDBNewLogger这类函数。重点在三点:
• 参数用Option结构体封装,别堆七八个参数(比如NewServer(host, port, timeout, maxConn...)
• 返回接口类型(如DB),不是具体结构体(如*MySQL
• 错误必须显式返回error,别panic——调用方得能处理驱动不支持这种失败场景
过度设计典型:为NewXXX硬套“Creator接口+实现类”,除非你真要运行时动态切换整套实现(比如测试/生产环境完全不同的DB层),否则纯属自找麻烦。

装饰器 ≠ 继承,HTTP中间件就是最自然的写法

Go里装饰器靠闭包和组合,核心签名就一个:func(http.Handler) http.Handler。所有日志、鉴权、限流中间件都该长这样:
• 输入是http.Handler,输出也是http.Handler
• 不改原始handler,而是包装一层新逻辑后返回新handler
• 别试图用嵌入或继承模拟“装饰器类”,Go没这必要
容易踩坑:在中间件里直接修改传入的http.Requesthttp.ResponseWriter,导致下游handler行为异常;正确做法是用httputil.NewSingleHostReverseProxy这类包装器,或自己实现ResponseWriter接口做拦截。

易优cms汽车车辆租赁源码1.7.2
易优cms汽车车辆租赁源码1.7.2

由于疫情等原因大家都开始习惯了通过互联网上租车服务的信息多方面,且获取方式简便,不管是婚庆用车、旅游租车、还是短租等租车业务。越来越多租车企业都开始主动把租车业务推向给潜在需求客户,所以如何设计一个租车网站,以便在同行中脱颖而出就重要了,易优cms针对租车行业市场需求、目标客户、盈利模式等,进行策划、设计、制作,建设一个符合用户与搜索引擎需求的租车网站源码。 网站首页

下载

接口定义越小越好,别为了“统一”硬凑大接口

Go接口的生命力在于小而专注。io.Reader只有Read()一个方法,io.Writer也只有Write(),但组合起来就能干大事。
反模式包括:
• 定义UserService接口,塞进CreateUpdateDeleteListGetByIDSearch……十几个方法,结果80%实现只用其中2个
• 为了让A/B两个模块“看起来一样”,强行让它们实现同一个大接口,结果各自补一堆panic("not implemented")
真正该做的:按调用方需要定义接口。比如某个函数只读数据,就只接收io.Reader;某个组件只发通知,就只依赖Notifier接口(含Send()方法)——其他方法它根本不需要知道。

最常被忽略的一点:设计模式不是填空题,没有“这个场景必须用观察者”的标准答案。你写完一段代码,如果发现要加注释解释“这里用了模板方法模式”,那八成已经过度设计了。Go的简洁性,恰恰体现在不用模式也能把事情说清楚。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

185

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

233

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

345

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

211

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

400

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

302

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

196

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

702

2025.06.17

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

98

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 827人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号