-
断点续传需手动设置Range头并校验服务端支持:先HEAD检查Accept-Ranges,再用http.Client发起bytes=start-请求;本地文件需Seek定位写入,配合Truncate容错;遇416或中断时比对ETag/Content-Length决定全量重下或指数退避重试。
-
配置GOPROXY、GOCACHE和GOMODCACHE以加速依赖下载与编译复用,使用air等热重载工具实现增量构建,禁用CGO减少开销,通过gotest并行测试与合理目录划分提升测试效率,并利用-gobuild-x、-cpuprofile及pprof分析性能瓶颈,保持环境整洁可显著提升Go本地开发效率。
-
Pod是Kubernetes调度和管理的最小单位,本质为共享网络、存储且共进退的容器协作单元;底层由pause容器占住网络命名空间并作为根进程维持Pod生命周期;调度经过滤与打分两阶段;状态需结合describe和logs深入排查。
-
net/http.Hijacker是Go标准库中用于劫持HTTP连接的接口,必须在需绕过HTTP协议栈直接操作底层TCP连接时使用,如WebSocket升级、HTTPS代理隧道、自定义二进制协议等;调用前响应未写出,且HTTP/2环境下不可用。
-
泛型最适合处理“逻辑相同、仅类型不同”的重复函数,如SumInts、SumFloat64s等;它通过类型参数化实现同一套逻辑在有限数值/可比较类型上的安全复用,而非盲目适配任意类型。
-
必须用fynepackage打包而非gobuild,因需自动嵌入平台元信息(如macOS的Info.plist、Windows的manifest)、绑定资源路径,并正确处理生命周期;手动构建会导致双击无反应、黑屏或弹控制台。
-
Go推荐用os.CreateTemp和os.MkdirTemp创建临时文件与目录,支持自动命名、权限与路径安全;测试中优先使用t.TempDir()和t.Cleanup()实现自动清理。
-
必须用gobuild-gcflags="-l-N"重新构建二进制,否则火焰图只显示0x41a2c8等地址而无函数名;-l禁用内联、-N禁用优化以保留栈帧和符号信息。
-
Go项目目录结构无强制规范,但cmd/下须按可执行名建子目录(如cmd/api),main.go仅做配置加载、依赖初始化和app.Run()调用;internal/是编译器级私有边界,外部导入即报错;测试文件必须与源码同目录同包且以_test.go结尾。
-
应根据需求层级选择:只需单层目录列表用os.ReadDir,需递归遍历整个目录树用filepath.WalkDir;旧版Go兼容可选filepath.Walk,但推荐升级迁移。
-
应使用pprof、Prometheus和OpenTelemetry构建分层可观测体系:pprof暴露运行时诊断指标,需正确启动HTTP服务并限制访问;Prometheus上报业务指标,须全局注册、避免重复;OpenTelemetry统一追踪与指标,确保context透传;禁用无上下文的os.Getpid()或runtime.NumGoroutine()健康检查。
-
&v总是指向循环变量副本的栈地址,而非原切片元素;修改*p不影响原数据,因v是独立局部变量,生命周期仅限当轮迭代。
-
需确保密钥长度为16、24或32字节,显式校验len(key);密钥应由crypto/rand生成或经PBKDF2派生;base64解码后必须验证长度;NewGCM等构造函数须检查error,不可忽略;RSA解密失败不透露细节,应确认密钥对匹配且密文完整;严禁使用math/rand生成密码学随机数。
-
在Go中实现HTTP流式响应(如服务器发送事件或长连接日志推送)时,需主动调用http.Flusher.Flush()手动刷新缓冲区,否则ResponseWriter的默认缓冲机制会导致前端HTML无法及时接收数据。
-
根本原因是连接生命周期管理失配、错误未分类重试及超时参数不协同;database/sql默认不探测连接存活,需设SetConnMaxLifetime≤5分钟、启用checkConnLiveness=true实现自动坏连接替换与重试。