-
Go的net/http能写生产级RESTAPI,但裸用http.HandleFunc无法处理路径参数、JSON解析、统一错误响应和中间件复用;应优先选用gorilla/mux等轻量路由库,并封装JSON和错误响应函数以保证一致性。
-
runtime.NumGoroutine()返回当前程序中正在运行或处于等待状态的goroutine总数,包括用户创建和runtime内部协程,是瞬时、无锁、低开销的整数快照。
-
为什么直接用sync.Map不适合做业务缓存因为sync.Map是为高并发读多写少场景优化的底层结构,缺乏过期、淘汰、统计等缓存必需能力。它不支持TTL(Time-To-Live),不能自动驱逐旧数据,也没有命中率监控接口——这些在真实服务中几乎必须。用sync.Map手动实现过期逻辑,会引入定时器或懒检查,极易导致内存泄漏或时序错误没有容量限制,缓存无限增长,可能触发GC压力或OOM无法区分“未命中”和“值为nil”,业务层需额外包装,增加出错概率推荐方案:用gi
-
应返回零值结构体+nil错误而非nil+sql.ErrNoRows,以区分“查无结果”与“数据库异常”;避免包装sql.ErrNoRows,字段优先用值类型确保零值安全,混用ORM时需统一空对象适配。
-
reflect2更快是因为缓存类型信息、避免重复检查与分配,将反射编译为近原生调用;适用于高频序列化、ORM等场景,但需注意API不兼容、Go版本兼容性风险及低频场景无需替换。
-
RedisStreams是Go中最实用的轻量级分布式队列方案:支持消费者组、ACK、水平扩展;需注意XADD限长、XGROUP预创建、XCLAIM处理pending消息。
-
Pebble数据库需用pebble.Open()初始化并检查err,Close()必须调用以防止数据丢失;路径须可写,Options至少设BytesPerSync和FS;Get/Put要求[]byte且key不可为nil;批量写需防超长key;Pebble适用于高吞吐OLTP场景,无SQL、事务隔离或二级索引。
-
在Go语言中,使用==操作符比较指针和值时有明确区别。1.指针比较检查是否指向同一内存地址,2.值比较检查内容是否相同。基本类型如int、string等直接比较值;指针比较地址,即使内容相同但地址不同则不相等;结构体和数组可比较当所有字段或元素均可比较;切片、映射、函数仅能与nil比较,非nil时需手动遍历或使用自定义方法实现内容比较。接口比较需动态类型和值均相同。实际开发中,身份识别、缓存命中等场景使用指针比较,内容相等性判断则用值比较,不可比较类型需自定义Equal方法处理。理解这些差异有助于编写高效
-
Go指针本质是存储变量地址的值,核心操作为取地址(&)、解引用(*)和传地址副本;参数永远传值,传指针即传地址拷贝,可修改原值;nil指针需判空避免panic;小类型优先值传递,大结构体或需修改时用指针。
-
Go编译器因无法确定包初始化顺序而拒绝编译import循环;解法包括:抽取公共类型至独立types包、用接口+依赖注入替代直接调用、警惕\_导入和init()引发的隐式循环。
-
IPv6地址字面量必须用方括号包裹,否则Go标准库解析失败;URL、监听地址、多播绑定等场景均需显式使用[::]或[2001:db8::1]格式,并注意ZoneID处理与双栈配置。
-
Go语言中if语句支持多条件组合与嵌套,用于实现复杂分支逻辑。1.使用&&、||、!连接多个条件,如ifx>=0&&x<10判断范围;2.可结合短路求值优化性能,将易为假的条件前置;3.支持if-else和elseif结构处理互斥条件;4.嵌套if适用于层级判断,如登录权限控制,但不宜超过三层;5.常用于输入校验、状态机等场景,需注意表达式清晰性与括号优先级。合理使用可提升代码可读性与可靠性。
-
Viper默认不展开嵌套键,需显式调用SetConfigType("yaml")并正确设置文件路径;环境配置推荐多文件叠加(base+env),结构体绑定需导出字段+mapstructure标签,热更新需指针封装避免竞态。
-
本地消息表必须与业务表同库,因需单机事务保证“业务操作+消息落库”原子性;跨库会导致订单成功但消息丢失,引发永久数据不一致。
-
使用互斥锁、channel、减少共享变量和限制并发数可有效降低goroutine竞争。优先通过channel通信替代共享内存,读多写少用RWMutex,避免频繁操作全局变量,结合workerpool控制并发规模,提升程序稳定性与性能。