-
gRPC是Go新服务首选,因生态成熟、跨语言、原生流式支持;Twirp仅适合简单POC或JSON兼容场景;Thrift和net/rpc在新项目中均不推荐。
-
正确设置需同时满足传输层和运行时条件:Secure仅在HTTPS下生效,开发时用r.TLS!=nil自动判断;HttpOnly防XSS且无兼容问题;SameSite必须显式设为Lax以平衡安全与可用性;优先用MaxAge控制过期。
-
Builder结构体返回指针而非值以支持链式调用:值接收器复制实例导致字段不累积,指针接收器共享状态使配置持续叠加;Build()应返回error而非panic以保障调用方可控;嵌套配置需通过中间Builder或函数式接口确保封装与链式;Builder不可并发复用,须每次新建实例。
-
Go中sync包提供Mutex保障共享数据读写安全、WaitGroup协调goroutine生命周期;Mutex需作为结构体字段配defer解锁,WaitGroup须先Add后启动goroutine并deferDone。
-
不能直接用errors.New("xxx")定义全局错误,因为每次调用都会创建新对象,导致==比较失败;正确做法是用包级var声明一次Sentinel错误变量,如varErrNotFound=errors.New("usernotfound"),并统一使用errors.Is判断。
-
Go中组合模式需用接口定义Component行为,容器节点嵌入切片存子节点,避免继承;注意递归安全、路径归一化、并发锁和封装性。
-
strconv.Atoi返回error时需用iferr!=nil检查并处理,不可忽略;可类型断言*strconv.NumError获取详情,用errors.Is(err,strconv.ErrRange)等标准方式判断错误类型;推荐封装SafeAtoi函数提供默认值,或改用更灵活的strconv.ParseInt。
-
Golog包不支持错误级别和结构化输出,需替换默认logger、补齐上下文、控制格式与目标;推荐zap/zerolog,记录error时保留错误链和调用栈,按严重性分流输出,避免无效日志。
-
flag.String和flag.StringSlice行为不同:前者仅存最后一个值,后者支持多值;自定义flag.Value必须同时实现Set和String方法;flag.Parse()必须在所有flag定义之后调用。
-
应使用占位符image.repository和image.tag并通过values.yaml或--set注入,而非硬编码镜像地址;Dockerfile中二进制路径需与deployment.yaml的command/args严格一致;配置应通过ConfigMap挂载+Viper热重载,敏感信息用Secret;Chart版本须与gittag和Go二进制版本同步。
-
Go中import是编译期关键机制,非语法糖:标准导入(import"fmt")最安全;别名导入(importjson2"github.com/your/json")用于解冲突或缩略长名;匿名导入(import_"net/http/pprof")只执行init();点导入(import."fmt")明确禁止。
-
状态模式在Go中更清晰因其接口隐式实现、组合设计及context.Context的灵活使用。1.接口隐式实现减少冗余代码,使状态结构体更轻量;2.组合优于继承,通过嵌入或参数传递context提升状态隔离性与可测试性;3.Context支持层级结构,便于携带状态信息、控制超时取消,提升调试追踪能力;同时需注意避免滥用context.Value、管理context生命周期及确保状态切换线程安全。
-
tail-f+grep--color不够,因丢行、不支持多关键字“且”逻辑、冲掉原始颜色、无法回溯;Go中bufio.Scanner需设Buffer限长防超长行panic。
-
值类型和指针对接口实现有重要影响。1.类型T的方法集包含接收者为T的方法,T的方法集包含接收者为T和T的所有方法。2.若接口方法需通过指针调用,则只有*T能实现该接口。3.值接收者适用于小结构体、只读操作或不可变数据,如Point的Distance方法。4.指针接收者适用于修改字段、大结构体或保持一致性,如Cache的Put方法。5.接口赋值时,若由指针实现,只能将指针赋值给接口;若由值实现,值和指针均可赋值。6.常见错误是定义指针接收者方法却用值赋值接口,可能导致运行时panic。7.选择应基于方法集规
-
json.MarshalIndent用于生成带缩进的可读JSON,参数prefix控制每行开头前缀,indent控制嵌套缩进符;需确保结构体字段导出、正确使用tag,且调用后用string()打印结果。