-
MD5和SHA是单向哈希算法,不可逆,仅用于校验或密码加盐;AES是对称加密算法,支持加解密,推荐使用AES-GCM模式。
-
飞书机器人Webhook地址必须以https://开头且无空格或换行,需用strings.TrimSpace()清洗并校验前缀;日志告警应通过异步Hook实现,避免阻塞主流程。
-
Goldenfile测试是通过字节比对验证确定性文本输出是否被意外修改的实践,需用filepath.Join动态生成路径、统一LF换行、bytes.Equal精确比对,并通过-update标志安全更新,配合cmp.Diff定位差异。
-
sync.Map适合读多写少、无过期淘汰需求的轻量场景,如配置热更新;需TTL、LRU或容量控制时应选gcache、bigcache、freecache或ristretto等第三方库。
-
Go编译Windowsexe需显式设GOOS=windows和GOARCH,否则生成非PE文件;闪退多因CGO依赖VC++运行库,应设CGO_ENABLED=0;-o仅控制输出名,图标、版本等需go-winres等工具处理。
-
优先用channel传递数据或协调执行顺序,因其天然支持所有权转移与阻塞同步;仅保护少量共享状态时,Mutex更轻量高效。
-
用container/heap实现可修改优先级队列需封装结构体并完整实现heap.Interface,包括Less、Swap、Len、Push、Pop;关键是在任务结构中维护index字段,并在Swap/Fix时同步更新,以支持O(logn)优先级调整。
-
值接收者可以实现接口并支持多态,但不能修改接收者状态;指针接收者可修改对象状态且仅能由指针实现接口。1.值接收者方法可被值或指针调用,适合不修改状态的场景;2.指针接收者方法只能由指针实现接口,适用于需修改状态的情况;3.值类型赋值给接口时自动复制,指针接收者方法修改的是原对象;4.多态成立与否取决于方法集,而方法集与接收者类型相关。
-
使用go:embed将静态资源打包进Go程序,能实现单文件部署、避免路径问题、简化依赖管理。1.定义变量接收资源内容,类型通常为embed.FS;2.使用//go:embed指令指定要嵌入的文件或目录;3.编译时资源被直接打包进二进制文件;4.通过fs.Sub创建子文件系统以正确访问资源路径;5.可启动HTTP服务器直接服务内嵌资源。常见用法包括内嵌单个文件、多个文件、整个目录(递归或非递归)。使用时需注意控制文件体积、处理路径差异、平衡开发与生产环境需求,并明确其不适用于动态资源更新场景。
-
gorilla/websocket的CheckOrigin必须显式覆盖,因其默认严格校验Origin头,仅允许与服务地址完全一致的来源,否则返回403;它在WebSocket握手阶段执行,早于中间件和handler,CORS无效;生产环境禁用returntrue,需用白名单精确匹配协议、域名、端口。
-
使用channel或errgroup收集goroutine错误:通过带缓冲channel配合WaitGroup收集所有错误,或用errgroup自动处理首个错误并取消其余任务,根据是否需收集全部错误及上下文控制需求选择方案。
-
缓冲通道容量非零不等于不阻塞:缓存满时发送仍阻塞;无缓冲通道要求收发同步;死锁常因满缓冲无接收者;缓冲大小应匹配生产消费节奏而非盲目增大;select+default仅瞬时探测,不可靠;range遍历未关闭通道会永久阻塞;关闭责任在最后发送方,向已关闭通道发送会panic。
-
正确关闭channel需等待所有生产者退出,否则向已关闭channel发送数据会panic;多channel接收应结合select与done信号避免阻塞。
-
缓存双删不是简单删两次,第二次删除必须延迟执行以确保DB写入完成,且需幂等、解耦、监控返回值,并适配本地缓存与主从延迟。
-
Go坚持“一切皆值传递”原则,函数参数、返回值、赋值均复制值;切片/map/channel是含指针的值类型,复制header而非底层数组;需修改原始值时才用指针。