golang
已收录文章:180篇
-
Go通过返回error类型显式处理网络错误,需每次操作后检查;2.常见错误包括连接超时、主机不可达、连接重置等,可通过*net.OpError类型断言判断;3.利用Temporary()和Timeout()方法区分临时性与永久性错误,指导重试策略。129 收藏
-
多模块微服务架构通过合理划分业务边界和依赖管理提升可维护性。1.项目按业务域拆分为多个module,如user-service、order-service和shared组件;2.各module通过go.mod定义依赖,开发时可用replace指向本地共享模块;3.使用go.work实现工作区模式,简化多模块协同开发;4.共享模块应轻量且版本化,服务间通过API通信而非直接引用,确保解耦与独立交付。452 收藏
-
Go语言通过ParseMultipartForm和MaxBytesReader限制文件上传大小,防止内存耗尽。ParseMultipartForm设置请求总大小上限并缓存内存,超限部分存临时文件;结合handler.Size校验单个文件大小,中间件统一限制更高效。186 收藏
-
select语句是Go语言多路复用核心机制,通过类似switch结构处理多个channel的发送或接收操作,实现非阻塞并发通信,提升程序并发效率与响应能力。483 收藏
-
享元模式通过共享内在状态减少内存使用,Golang中结合工厂模式与并发安全map实现对象复用,适用于大量相似对象场景,显著降低GC压力,但增加设计复杂性。481 收藏
-
使用接口抽象或输出重定向可有效测试Go日志。1.定义Logger接口并注入,测试时用MockLogger捕获输出;2.重定向标准log到buffer进行断言,需注意并发安全;3.第三方库如zap提供zaptest等工具支持精细控制与自动验证,提升可观测性。450 收藏