-
手动触发GC不一定能解决内存泄漏,因其仅发起回收而不保证完成,且无法清除仍被根引用的泄漏对象;应结合MemStats监控HeapAlloc/HeapObjects曲线、pprof分析间接引用链,并用goroutine栈dump排查协程泄漏。
-
Go中定义接收任意多个字符串的变长函数需用funcname(args...string)语法,...string必须位于参数列表末尾,args在函数内为普通[]string切片,调用时可传零个、多个字面量或加...展开的切片。
-
原子操作仅适用于单字段无竞争场景,多字段协同、高竞争或需内存序保证时应优先用mutex;结构体字段不可直接原子更新,须拆分或用atomic.Value;忽略内存序在非x86架构易出错。
-
nats.Connect连不上JetStream是因服务端未启用,需加-js参数或配置jetstream块;js.Publish失败、消息丢失、重复消费等问题均源于JetStream未正确配置和使用。
-
使用gorilla/websocket在Golang中实现文件传输需遵循以下步骤:1.建立WebSocket连接,通过Upgrader结构体将HTTP升级为WebSocket;2.发送端分块读取文件并通过conn.WriteMessage发送;3.接收端持续监听并拼接数据至文件完成;4.可扩展发送元信息以支持多文件及进度显示;5.注意缓冲区大小、并发控制和错误处理。整个过程依赖于WebSocket的字节流特性,确保数据可靠传输。
-
Worker启动时必须接收context.Context参数,否则上层无法取消;传context.Background()或内部新建独立ctx均导致ctx.Done()永不触发、select无法响应取消。
-
Protobuf的Go实现不支持反射直接序列化struct,必须使用protoc-gen-go生成的类型;Avro的Go库(如hamba/avro)支持运行时schema+reflect,适用于动态适配场景。
-
Gin本身无内置优雅关闭,需用http.Server.Shutdown()配合signal监听和context超时,手动管理所有goroutine退出;漏掉任一环节(如ticker、DB、Redis或子goroutine未响应ctx.Done)将导致进程卡住。
-
sync.Map适用于小流量、单机、QPS几百的幂等场景,但无自动过期、不跨进程;需用结构体缓存结果、定时清理、避免key污染,Redis需原子SetNX+EX,DB唯一索引为兜底。
-
Example函数必须以Example开头且无参数:命名须为funcExampleXXX(),放于_test.go中同包,用fmt.Println打印输出,运行用gotest-run^Example,文档通过godoc或pkg.go.dev查看。
-
Gio是即时模式2D渲染库,非传统GUI框架;黑屏主因是漏掉op.InvalidateOp{}.Add(ops)或未调用gtx.Layout();输入需手动注册pointer.InputOp/key.InputOp并拉取事件;widget.Clickable适合简单点击,复杂交互须用底层pointer.InputOp。
-
goroutine中panic无法被外层defer捕获,必须在每个goroutine内部用deferrecover()处理;errgroup.Group可安全统一管理多goroutine错误;channel发送错误需避免关闭后发送或死锁。
-
使用os.CreateTemp可安全创建唯一临时文件,需指定目录和带*的模式名,通过defer清理资源,并设置适当权限以确保安全性和稳定性。
-
os.MkdirAll可一次性创建多级目录且自动处理父目录缺失,接收路径字符串和os.FileMode权限(如0755),成功返回nil(含路径已存在情况),失败返回具体错误;推荐用filepath.Join构建跨平台路径并显式指定权限,务必检查错误。
-
用map+sync.RWMutex可实现轻量级线程安全服务注册发现:定义Registry结构体封装带读写锁的map,注册需加写锁查重并更新心跳,发现用读锁;后台goroutine通过ticker定期清理超时实例;HTTP接口需规范方法、JSON解析与错误处理;客户端用非阻塞心跳机制并设超时重试。