-
Go中滥用设计模式适得其反,因其无类继承、隐式接口、强调组合;推荐Interface+值类型组合、Option函数式配置、Context-awarepipeline三种Go友好模式。200 收藏 -
最直接的文件写入方式是os.Create配合Write,适合小量数据覆盖写入;需手动处理目录创建、字节转换、换行符及Close()调用。413 收藏 -
RWMutex仅适用于读远多于写的场景,写占比超15%~20%时性能反不如Mutex;必须成对使用RLock/RUnlock,禁止锁升级,慎用饥饿模式。232 收藏 -
Go的encoding/json包可靠但需规范使用:1.字段名用jsontag显式绑定snake_case;2.空值用*T或sql.NullT;3.嵌套结构与切片类型须严格匹配;4.解析前校验HTTP状态码。459 收藏 -
因为go/parser专为Go源码设计,不支持裸表达式、自定义优先级和函数调用;需用递归下降解析器,按括号>乘除>加减分层处理,变量与函数在ParseFactor中统一识别,并注意空格、浮点数、错误恢复和括号匹配。214 收藏 -
Go语言中通过channel和goroutine实现多生产者多消费者模式,使用有缓冲channel传递任务,生产者并发发送任务,消费者从channel读取并处理,所有生产者完成后关闭channel,消费者在channel关闭后自动退出,配合sync.WaitGroup确保协程同步,避免资源竞争与泄漏。323 收藏 -
值类型传递会复制数据,各goroutine操作的是副本,不影响原值;2.在for循环中通过闭包引用循环变量时,所有goroutine可能共享同一变量,导致数据竞争和意外结果。471 收藏 -
Redis分布式锁易出错因原子性、自动续期、安全释放未对齐;需唯一标识、Lua校验释放、独立心跳续期;etcd的CAS+Lease更可靠;数据库行锁仅适用于低频短时场景。280 收藏 -
Go反射无法跨包访问未导出字段,因Interface()等方法要求字段导出且可寻址,否则panic;安全做法是使用导出字段或原包提供的getter/setter方法。125 收藏 -
Go允许声明无函数体的函数,用于对接外部实现(如汇编代码),标准库中大量数学函数(如math.Floor)即采用此机制,在.s汇编文件中提供具体实现。444 收藏 -
令牌桶算法适合控制平均速率和突发流量,Go可用rate.Limiter实现;支持按用户/IP精细化限流;分布式场景推荐Redis+Lua脚本;需增强可观测性与降级能力。458 收藏 -
Go原生map非并发安全,多goroutine读写必崩溃;sync.Map适用于读多写少场景,需用Store/Load等方法而非下标操作,且须注意类型断言和内存开销。373 收藏 -
GoWeb服务器因工作目录与相对路径不匹配,常导致/css/等静态资源返回404;核心在于http.FileServer的路径解析依赖运行时工作目录,而非源码位置。224 收藏 -
gorilla/websocket是首选,因标准库net/http仅支持HTTP握手,不提供WebSocket帧解码、心跳等完整功能;硬写易出错且难应对生产问题。453 收藏 -
必须检查strconv.Parse*函数的error,否则静默失败;Atoi不处理空格、小数点、进制前缀;ParseInt需显式指定base和bitSize;Itoa仅支持int十进制,FormatInt更通用;ParseFloat位宽非精度,FormatFloat精度依赖格式符;ParseBool不支持"yes/no"等常见值。107 收藏