Go语言技术文章
-
runtime.Stack经常返回空或截断堆栈,因其默认仅捕获当前goroutine且受缓冲区大小限制;传nil或过小buf会导致截断或乱码,需预分配足够空间(如1MB),获取全量堆栈须传true但有STW风险,推荐优先使用pprof。105 收藏 -
GoHTTP服务panic致进程退出的根本原因是Server不捕获handler内panic,导致goroutine崩溃、ListenAndServe异常返回;需用panicHandler包装器统一recover并记录堆栈,配合ErrorLog和Shutdown避免资源泄漏。105 收藏 -
Go程序不该手动fork守护化,因runtime状态无法安全复制,易致调度异常、信号丢失或卡死;应交由systemd以Type=simple管理,配合Restart=on-failure和StandardOutput=journal。105 收藏 -
Go构建RESTfulJSON接口的核心是net/http包配合结构体序列化,需定义带json标签的导出字段结构体、用json.Decode解析请求体、json.Encode生成响应、正确设置Content-Type头及HTTP状态码。105 收藏 -
应直接使用golang.org/x/time/rate而非手写令牌桶:它已通过高并发、时钟漂移、上下文取消等验证;channel实现存在时钟跳变失准、不支持多令牌消耗、无Delay预估等缺陷;需缓存time.Now()避免单请求内时钟抖动误判;按IP/用户ID用sync.Map管理独立限流器;burst是最大积压数非并发数;HTTP中优先用limiter.Wait(r.Context())并确保ctx可取消。102 收藏 -
select分支执行顺序是伪随机轮询而非随机或按代码顺序;当多个case就绪时,Go以per-Goroutine伪随机起始索引轮询,防饿死但不可预测;default优先级最高,仅有一个case就绪则直接执行,全阻塞则goroutine挂起。101 收藏 -
测试多线程函数需解决执行顺序不可控、资源竞争和测试提前结束问题,应使用sync.WaitGroup或channel确保所有goroutine完成。101 收藏 -
gomobile不是UI框架,仅将Go函数编译为AndroidAAR或iOSFramework供原生调用;必须指定合法module路径(不支持.),Android需main包含main函数,iOS需//export注释导出函数。101 收藏 -
以慢接口排查为线索,讲 Go pprof 的 CPU、heap、goroutine、block profile 使用顺序和常见误判。101 收藏 -
值类型直接存储数据,变量间相互独立;指针类型存储地址,可共享和修改同一内存数据。100 收藏 -
GoHTTP服务器需显式创建ServeMux、校验Method/Content-Type、配置超时、包装ResponseWriter以实现可观察性与可靠性。100 收藏