-
直接选qrcode(github.com/skip2/go-qrcode),它更轻、无依赖、API简单且默认支持UTF-8中文;go-qrcode无中文兼容,易乱码或panic。
-
Go标准库net/http足以构建轻量可靠的RESTfulAPI;应使用http.ServeMux路由、统一路径风格、正确设置Content-Type与状态码、封装JSON响应、复用标准错误处理、全程传递context控制超时。
-
Go语言通过Goroutine实现高并发,每个请求由独立协程处理,结合sync.Pool降低GC压力,并通过配置ReadTimeout、WriteTimeout、IdleTimeout和MaxHeaderBytes等参数优化HTTPServer性能,提升系统稳定性和资源利用率。
-
使用time.Ticker可实现每5秒并发执行独立任务;2.time.AfterFunc适合延迟10秒后执行一次性任务;3.结合context与channel可优雅管理多个定时任务的生命周期,避免goroutine泄漏。
-
WebSocket断开时ReadMessage返回1006错误是正常现象,需立即停止读循环、关闭连接并退出goroutine;应主动发CloseMessage、用context协同退出、设读写deadline、用sync.Map安全管理连接及清理。
-
Go的switch支持任意可比较类型表达式,如整数、字符串、布尔值、指针、struct(字段全可比较)等;不支持切片、map、func及含它们的类型;case默认自动break,fallthrough需显式声明且仅限末尾;无表达式时等价于if-else链。
-
Go标准库flag包轻量高效,支持基础类型参数、自动帮助信息和错误处理;需用flag.String等声明参数指针,调用flag.Parse()解析;支持短长选项绑定、自定义Value类型及位置参数提取。
-
Go可用net/smtp发信、go-imap收信,需正确选协议端口、用标准Auth类型、设HTML头与CRLF换行、环境变量存密;收信须TLS加密、Gmail配应用密码;错误要细判状态码并分类重试。
-
Protobuf解包慢的主因是proto.Unmarshal参数误用:未复用结构体、未预分配缓冲区、未启用DiscardUnknown、误用gogoprotounsafe_unmarshaler等;应改用对象池、切片预处理、官方protoc-gen-go生成代码、unsafe.Slice(仅限可信长度场景)并缓存字段映射。
-
gomodinit报错“cannotfindmoduleprovidingpackage”主因是路径非法:项目位于$GOPATH/src下、含空格/中文,或模块名未用合法域名格式;应移出GOPATH、用gomodinitexample.com/myapp、删vendor/再试。
-
Golang减少GC压力的核心方法是“少分配、复用、控制生命周期”。1.避免在循环或高频函数中频繁创建对象,应预分配并在循环内复用;2.使用sync.Pool缓存临时对象,适合生命周期短且开销大的对象,并设置New函数生成实例;3.控制结构体大小与字段类型,按类型对齐减少浪费,避免嵌套过深,小对象尽量传值;4.利用对象复用技术如bytes.Buffer的Reset方法,结合sync.Pool提升复用效率。
-
用github.com/twpayne/go-geom的ContainsPoint最稳,需确保多边形外环逆时针、坐标统一(WGS84或投影),避免手写射线法导致边界错误。
-
安全加锁需用SETkeyvalueEXsecondsNX原子命令,value为唯一clientID;解锁和续期必须用Lua脚本校验value再操作,防误删与错续;单节点Redis锁在正确实现下已足够可靠。
-
Go语言内容安全审核需依赖第三方API(如腾讯云、阿里云)或本地AC自动机,禁用简单正则;须处理编码、变形词、绕过手段,并兼顾业务粒度与容错机制。
-
装饰者模式在Go中通过接口定义行为契约、结构体组合持有被装饰对象实现“透传+增强”,支持无限链式包装;需统一接口、正确透传调用、避免副本丢失,并推荐用构造函数封装初始化以保障安全。