-
指针比较基于内存地址:p1==p2为true因指向同一变量,p1==p3为false因地址不同,nil指针间相等;不同类型指针不可直接比较,需类型一致或转换;函数中可比较指针是否引用同一对象,值相等不意味指针相等。
-
Orchestration更适合强一致性、可追踪、易调试场景,需SagaCoordinator状态机协调;Choreography适合松散事件驱动协作,但须本地落库+幂等补偿。二者选型取决于失败传播责任边界。
-
Go中数组固定长度、值类型,切片动态灵活、引用底层数组;数组初始化需指定长度如[3]int{1,2,3},切片用[]int{1,2,3}或make([]int,3);截取切片共享底层数组,索引越界会panic。
-
net.ParseCIDR解析失败主因是输入格式不符,必须为“IP/掩码位数”形式;判断IP是否在子网应使用net.IPNet.Contains,避免手动计算;IPv4/IPv6映射由Contains自动处理;高频场景需预解析并缓存CIDR。
-
不可靠,因map遍历顺序随机且reflect.DeepEqual对nil/空slice、未导出字段、func、interface{}中类型不一致零值等场景处理失败;推荐用cmp.Equal配合cmpopts定制化比较。
-
time.Now().Unix()返回自Unix纪元起的整秒数(int64),无毫秒精度;需毫秒用UnixMilli()或UnixNano()/1e6;还原时间须显式传纳秒偏移(如0);解析字符串务必指定时区,避免跨时区误判。
-
告警规则应结构化为导出字段的Rule结构体,用JSON/YAML加载,operator存字符串以利扩展;通过fsnotify热加载并双变量+读写锁保障安全;构建device_id与metric两级索引优化匹配性能;增加duration_sec和suppress_window_sec支持时间窗口与去重抑制。
-
直接用chanint易卡死因无缓冲需同步收发:生产者发送时消费者未启动即阻塞,导致死锁;须用make(chanint,N)设缓冲、go启动双端、生产者close()后消费者用range安全退出。
-
Go结构体字段必须首字母大写(导出)才能被json.Marshal序列化;小写字母开头的字段会被忽略,导致输出空对象{}。本文详解结构体JSON转换原理、正确用法、标签控制及错误处理最佳实践。
-
CGO中C.CString分配的内存不释放会导致持续内存泄漏,RSS不断上升直至OOM;必须配对C.free,且需根据C函数文档判断返回指针是否需手动释放。
-
gotest-bench不是压力测试,它仅测handler内存执行开销,需禁用sleep、加b.ResetTimer、用-benchmem查分配;vegeta是轻量HTTP压测首选,支持P95/P99和直方图;手写脚本需控并发、复用client、禁keep-alive;压测必采pprof,关注调度器、锁、GC瓶颈。
-
pprof默认生成protocolbuffer二进制文件,需用gotoolpprof或可视化工具解析;直接cat或浏览器打开会乱码或报错;HTTP方式通过/debug/pprof/各路由获取profile,注意block/mutex等需显式启用;分析时需区分alloc/inuse、space/objects,避免误判内存泄漏;采样具有概率性,低频高开销问题需结合trace或日志验证。
-
在Golang中统一管理错误码的方法包括使用常量枚举定义错误码、构建结构化的自定义错误类型、在项目中统一使用并处理这些错误。1.使用iota定义错误码,如ErrCodeNotFound=1000,ErrCodeInvalidParam=1001,可提升可读性,避免魔法数字;2.封装AppError结构体携带错误码、消息及原始错误,支持日志记录和错误断言提取;3.全项目统一返回*AppError类型,接口层统一拦截错误并返回JSON格式,日志记录完整错误链;4.中间件如Gin框架中通过ErrorHandle
-
http.Server需显式配置超时与连接复用:ReadTimeout/WriteTimeout设5–10秒,IdleTimeout设30–60秒以复用连接,MaxHeaderBytes防内存耗尽。
-
Go的text/template包通过定义模板字符串、传入数据结构、执行渲染生成动态文本,轻量安全;支持字符串或文件解析模板,用结构体或map传参,提供条件判断、循环遍历等语法。