-
数组是固定长度的值类型,赋值会复制整个数组;切片是动态引用,通过指针、长度和容量管理底层数组,支持灵活操作如append和copy,开发中更常用切片传递集合。
-
Go结构体赋值默认是值拷贝:基本类型全复制,引用类型仅复制句柄;浅拷贝需手动处理slice/map/指针等;深拷贝推荐json序列化或copier库。
-
gRPCResolver必须实现resolver.Builder(含Build方法)和resolver.Resolver(含ResolveNow、Close方法),且Build必须返回非nil实例并触发首次解析,ResolveNow需主动刷新地址,Close需清理goroutine和channel。
-
类型断言适合已知有限具体类型的场景,如处理json.Unmarshal后的map[string]interface{},需用双返回值安全断言;反射仅用于类型完全未知或泛化操作,二者不可混用。
-
Go1.16起GO111MODULE默认on,但仍需手动设为on以确保行为一致;模块路径须按最终import地址预设(如github.com/yourname/mytool),避免简名或本地路径。
-
Casbin是Go生态RBAC权限控制的事实标准,支持多模型、不绑定框架,推荐用NewEnforcer快速启动,生产环境切换适配器并手动LoadPolicy,权限检查需透传资源ID、统一拦截返回403,模型文件字段顺序必须严格对齐,敏感操作须叠加二次验证与完整审计日志。
-
用http.Handler包裹业务逻辑可实现响应缓存,需同时重写Write和WriteHeader以捕获状态码与body,非GET/HEAD不缓存,key含method、path、query、accept,建议设max-age并禁用no-cache。
-
Go中方法必须绑定命名类型,函数则完全独立;值接收者操作副本,指针接收者可修改原值且更省内存;方法非一等公民,需显式绑定或闭包包装才能作为值使用。
-
Gohttp.Client优化需合理设置连接池参数与分层超时:MaxIdleConns、MaxIdleConnsPerHost、IdleConnTimeout控制复用,DialContext、TLSHandshake、ResponseHeader及Context四层超时保障健壮性,且须复用单例client。
-
log.Printf无法满足微服务日志追踪,因其不支持上下文透传;需通过context.Context自动携带trace_id,并在HTTP/gRPC调用及日志中统一注入与传递。
-
Go中defer按后进先出顺序执行,recover仅在defer函数内直接调用且同goroutinepanic时有效;子goroutinepanic需在其内部defer+recover处理,无法跨goroutine捕获。
-
Elem()只能用于指针类型reflect.Value,作用是解引用获取所指值的reflect.Value;非指针类型调用会panic,且nil指针解引用后返回invalid值。
-
灰度发布的核心是流量路由,需在HTTP或RPC入口实时判定请求特征并导向不同版本实例,关键在于依据Header等字段轻量打标而非服务拆分或Nginx分流。
-
Go语言中读取二进制文件可通过os.Open配合bufio.Reader分块读取,适用于大文件;或使用os.ReadFile一次性加载小文件;若文件按结构体存储,可用encoding/binary包解析,需注意字节序与写入一致。
-
GoHTTPhandler需手动解析Accept-Language头,按q值排序匹配支持语言;推荐使用github.com/nicksnyder/go-i18n/v2/i18n,避免context传localizer,前端通过API或全局对象同步翻译。