-
该用fmt.Errorf套%w而非%v是为了保留原始错误类型和链路,使errors.Is/As正常工作;%v会丢失底层错误,导致判定失败。
-
用gqlgen搭建GraphQL服务最省事:先写schema.graphql,运行gqlgeninit生成骨架,再用gqlgengenerate生成强类型代码,仅在resolver.go中实现匹配签名的业务逻辑,注意HTTP路由正确注册、resolver函数接收ctx且返回值类型与schema严格一致,每次schema变更后必须重新generate。
-
gRPCServer必须用credentials.NewTLS构造TLS凭证,不能直接传PEM路径;Client需显式加载CA根证书到tls.Config.RootCAs并启用验证;自签名证书须含SAN才兼容Go1.15+;端口、时间、证书链不全均会导致TLS握手失败。
-
享元对象必须不可变以保证线程安全,字段初始化后禁止修改,上下文数据应通过方法参数传入;推荐用sync.Pool替代带锁map实现工厂;键宜用可比较struct而非拼接string。
-
Go语言reflect包本身不提供并发安全保证,修改数组元素是否线程安全取决于是否对底层数据加同步控制;必须由开发者显式使用锁、原子操作等机制保障并发安全。
-
Gin的gin.Recovery()仅记录日志并返回固定500响应,不透出panic值、不执行自定义错误映射、不调用c.Error(),且会拦截后续recover逻辑;需禁用默认中间件并手写带堆栈记录与统一响应的PanicRecovery中间件,同时覆盖业务error和goroutinepanic。
-
Go中位运算符&、|、^、>>需严格类型匹配,&提取标志位,|组合标志,^切换标志,>>建议仅用于无符号类型;constiota定义标志时需显式指定类型或用1<<i避免类型错误。
-
切片是引用类型因其通过指针共享底层数组,结构含指针、长度、容量三字段;传递或切片时仅复制结构体,指针仍指向原数组,导致修改相互影响;函数传参或再切片均体现引用语义;避免副作用需用copy()或append创建独立副本。
-
GoRPC错误处理需区分调用失败与业务失败,前者通过返回error实现,后者应在Reply结构中嵌入错误字段如Errorstring或自定义AppError类型传递详细信息,同时避免panic并用defer+recover统一捕获异常,确保服务健壮性。
-
Go的database/sql不支持真正的bulkinsert,仅能通过多值INSERT实现伪批量;pgx的CopyFrom可实现PostgreSQL原生高效bulk,MySQL则需控制单次行数并调优连接与事务。
-
应避免在HTTPhandler中直接调用http.Error,改用自定义writeError函数统一返回JSON格式错误(如{"code":400,"message":"xxx","trace_id":"abc"}),并配合中间件兜底处理panic和未捕获错误。
-
Go原生HTTP客户端无法执行JavaScript,因此直接请求会获取到空容器(如<divclass="content"></div>);要抓取AJAX渲染后的真实内容,需模拟浏览器行为或逆向分析接口,本文详解两种可行方案。
-
Go错误处理需坚持三原则:不跳过iferr!=nil、不用字符串匹配错误、不丢弃原始err;正确使用%w包装、合理定义自定义错误类型、善用errors.Is/errors.As,才能保障错误链完整、诊断高效。
-
TF-IDF是词频-逆文档频率加权方法,Go因标准库无文本向量化支持需手写实现:清洗→分词→过滤→统计→向量化,用map和slice构建TF/IDF并计算余弦相似度。
-
Go语言复数类型为complex64或complex128,字面量如1+2i自动推导为complex128;complex()是构造函数而非类型,real()/imag()只读返回float64,需手动转换精度,共轭等操作需自行实现,math/cmplx包提供标准函数但需显式导入。