-
error是Go内建接口类型,定义为typeerrorinterface{Error()string},不可用==比较,应使用errors.Is/As;推荐errors.New和fmt.Errorf(含%w)创建错误,避免手动构造指针或忽略错误传播。
-
指针本身不影响性能,但间接访问和堆分配可能降低效率。传递大结构体时用指针减少复制开销,小对象传值更高效;字符串、slice、map等内置类型传值成本低。逃逸分析决定变量分配在栈或堆,指针外泄会导致堆分配,增加GC压力。避免过度使用指针,结合pprof和benchmark实测优化,优先保证代码清晰。
-
os.Symlink创建失败主因是路径未对齐:oldname为链接目标路径,若为相对路径则相对于newname所在目录;newname父目录必须存在;Windows需管理员权限或启用开发者模式。
-
需调用b.ReportAllocs()并加-benchmem标志才能统计allocs/op和B/op;allocs/op反映GC压力,应优先优化;ReportAllocs()需在ResetTimer前后调用,不可在Stop/StartTimer间;避免循环外初始化和闭包隐式分配。
-
Go中error字符串不建议以大写字母开头,因其面向日志与错误链拼接,小写更符合英文习惯、便于工具处理且符合标准库与linter(如ST1012)规范;而error常量名需大写以导出。
-
Go编译器禁止直接取普通局部变量地址并返回,因其会导致指针悬挂;它通过逃逸分析自动将需逃逸的变量分配到堆上,而显式取址返回则被静态拦截以保障内存安全。
-
Go中无传统指针泄漏,但不当持有指针会导致内存无法回收:如sync.Map/全局map用*Type作key、goroutine闭包捕获大对象指针、defer误捕获指针等,均因根可达性使对象图常驻内存。
-
Go中需显式检查指针是否为nil再解引用,因nil指针解引用会直接panic;所有可能为nil的指针(如函数返回、map查找、结构体字段等)都必须判空,常见场景包括json.Unmarshal后、HTTP请求嵌套字段、sql.NullString等。
-
Finalizer会显著拖慢GC周期,因对象需多存活一个GC周期且finalizer执行在独立goroutine中,易阻塞回收;应优先用显式关闭、避免对高频对象或栈变量使用,并严禁IO/锁/panic。
-
Go的json.Unmarshal不panic,所有错误均通过error返回;必须检查err!=nil,测试需覆盖非法JSON、字段标签对齐、json.RawMessage延迟解析及错误输入拦截。
-
必须用goenv+.go-version锁定Go版本,显式设置GOOS/GOARCH,go.mod的go指令需与之严格对齐,禁用goget-u,统一gopls+.golangci.yml配置,CI中校验依赖树一致性。
-
GoAPI网关核心是“要不要自研”而非“能不能做”,中等规模用gorilla/mux+net/http+中间件已足够;需强定制时才考虑自研,关键在路由、鉴权、限流、代理的正确实现与可观测性保障。
-
Gomap扩容时会新建2倍大小的bucket数组并渐进式迁移数据,导致写操作延迟抖动和内存短暂翻倍;可通过延迟抖动、HeapInuse突增或pprof中evacuate调用识别;预分配hint可避免早期扩容。
-
异步加载通过非阻塞方式提升页面性能。使用async、defer和动态脚本实现JS异步加载;内联关键CSS、异步加载非关键样式优化CSS;图片采用lazyloading与响应式加载;结合preload、prefetch提升资源优先级,合理运用可显著优化首屏渲染与用户体验。
-
GoHTTP中间件透传X-Request-ID和X-Env需在首层中间件提取并写入context.Context,HTTP出站请求手动Set头,gRPC调用通过metadata注入,避免使用c.Set和http.Post等易丢header的方式。