-
在Go中实现RPC超时控制需使用context包设置截止时间,通过context.WithTimeout创建带超时的上下文,结合select监听调用结果或超时信号,适用于net/rpc、HTTP及gRPC场景,其中gRPC原生支持context超时,而HTTP客户端可设置Timeout字段统一控制,建议合理配置1~5秒超时并配合重试与熔断策略提升系统稳定性。
-
Go语言布尔逻辑使用&&、||、!操作符,仅支持bool类型,不隐式转换;支持短路求值,常用于安全访问和防错;不可链式返回操作数值,须确保操作数为bool。
-
切片越界panic是运行时错误,无法用iferr!=nil捕获;它直接触发panic:runtimeerror:indexoutofrange,而非返回error,需通过边界检查(如i>=0&&i<len(s))预防。
-
Go中map的struct值不能直接修改字段,因m["k"]返回不可寻址的临时副本,底层扩容导致地址不固定,故编译期拒绝m["k"].field=x;正确方式是取出→修改→写回,或改用map[string]*Struct。
-
在Golang微服务中,消息队列通过解耦和异步提升系统可靠性与扩展性,推荐使用NATSJetStream实现发布-订阅模式,其轻量高性能且集成佳;RabbitMQ适合强可靠与复杂路由场景,Kafka适用于高吞吐日志处理,RedisStreams则适配已有Redis的中小规模应用;设计上需定义结构化消息契约、唯一subject命名、消费幂等性及错误重试机制,并将NATS客户端注入服务层实现安全复用,确保消息生命周期可控,系统稳定高效。
-
httputil.NewSingleHostReverseProxy是最轻量稳妥的反向代理起点,需正确设置Director、自定义Transport并处理Header、负载均衡与健康检查等细节。
-
端口被占用导致dlvbindsocketfailed,应先用lsof或netstat查进程,再换端口(如:2346)或加--accept-multiclient启动,VSCode需同步修改launch.json的port和配置。
-
直接用err.Error()即可,它是最标准、轻量且无副作用的方式;需先判空防panic,避免冗余包装或重复前缀,仅在需错误链支持时才用fmt.Errorf(...%w)。
-
使用Context、信号监听和WaitGroup实现Go程序优雅退出:通过context.WithCancel创建可取消的上下文并传递给协程,协程内定期检查ctx.Done()以响应取消信号;在主函数中用os/signal监听SIGINT或SIGTERM,收到信号后调用cancel触发退出流程;结合sync.WaitGroup跟踪活跃任务,确保所有工作协程完成后再退出,避免资源泄漏;最后进行超时控制与资源清理,如关闭网络连接、提交事务等,保障程序稳定终止。
-
recover只能在defer函数中生效,且仅能捕获runtime.panic()引发的panic;对runtime.throw()或fatal错误无效,且无法跨goroutine捕获。
-
Go的string本质不可修改,因底层为只读结构体{ptr*byte,lenint}且编译器未实现索引赋值操作;修改必须通过[]byte中转并重建新string。
-
绝大多数时候该用&MyStruct{},而非new(MyStruct);前者支持字段初始化和选择性赋值,后者仅分配零值内存且无法设字段,现代Go中new()几乎无必要。
-
URL编码查询参数必须用url.QueryEscape而非url.PathEscape,因其按application/x-www-form-urlencoded规范将空格转为+、中文转%XX;路径编码才用url.PathEscape。
-
UberFX强制代码按其结构组织,启动失败常见于缺少构造函数或类型未注册;必须用fx.Provide显式注册返回具体类型的构造函数,fx.Invoke仅接受参数可解析且返回error的函数,自定义日志需实现fxevent.Logger接口,fx.Supply仅适用于具体值注入。
-
Gomap是哈希表,底层为开放寻址哈希表(带溢出桶的数组结构),非有序、不支持并发读写,需手动加锁;key必须为可比较类型,初始化须用make或字面量;扩容渐进式,性能受负载因子和哈希均匀性影响。