-
指针逃逸是指局部变量的地址被传递到函数外部,导致编译器将其分配到堆上而非栈上,例如返回局部变量的指针时,因变量生命周期可能超出函数调用,必须堆分配以确保安全,典型场景包括返回指针、闭包捕获、发送指针到channel、存储于全局slice或map、interface{}装箱等,编译器通过静态逃逸分析判断指针流向,若发现可能被外部访问则判定逃逸,虽堆分配增加GC压力,但逃逸是保障正确性的必要机制,应避免在性能关键路径中不必要的逃逸,可通过传值替代传指针、减少闭包捕获、慎用interface{}和使用sync.
-
在Go语言中,new(T)和&T{}均用于获取类型T的零值指针,语义完全等价;二者生成的指针指向内存中初始化为零值的T实例,无功能或性能差异。
-
debug/elf打不开二进制主因是非ELF格式、文件损坏或stripped后缺失符号表;需用file/readelf验证格式,优先查.dynsym而非.symtab,解析时防索引越界,并配合DWARF调试信息定位源码行号。
-
安全反射读取结构体字段需先检查可导出性(PkgPath=="")和有效性(IsValid/CanInterface),按名取字段防偏移;map转struct时用strconv解析字符串、显式类型转换并校验CanConvert;调用方法前验证receiver非nil且匹配签名;缓存Type/Method而非Value,预计算字段信息,限制嵌套深度防栈溢出。
-
不能直接用sqlmock.Mock接口对接sql.DB,因它非sql.DB类型;须用sqlmock.New()创建mockDB实例并注入业务代码,且需检查错误、调用ExpectationsWereMet()。
-
Go中变量声明即初始化,零值是类型确定的默认值:数值类型为0,bool为false,string为空字符串,指针等为nil,struct各字段取零值,数组元素全为零;time.Time零值为0001-01-01UTC,需用IsZero()判断;reflect.ValueOf(nil)会panic,应传带类型的nil或直接比较零值。
-
Go中http.Client必须显式设置超时,否则DefaultClient会无限阻塞;需区分网络错误与HTTP状态码,用自定义error类型携带上下文,并对可重试错误实施指数退避重试。
-
swaginit生成docs/失败需检查三件事:一要确保已安装swagCLI工具;二须在项目根目录执行命令;三所有handler函数必须含完整注释块且以//@Summary开头。
-
命令模式通过将请求封装为对象,实现操作的参数化与日志追踪。在Golang中,定义Command接口并创建LoggedCommand装饰器,在执行前后自动记录日志,支持耗时统计与错误捕获,适用于审计与调度场景。
-
方法值t.Set是闭包式函数,类型为func(int),接收者已固化;方法表达式T.Set是普通函数,类型为func(*T,int),需显式传接收者。二者类型、参数、调用方式均不同,混用将导致编译失败。
-
time.Timer适用于一次性延时任务,如5秒后发送通知;需周期性执行应使用time.Ticker。通过NewTimer创建后,可监听其C通道等待触发,用Stop停止以避免资源泄漏,Reset可重设超时时间,常用于连接保活等场景。注意Stop后需处理C通道残留值,已触发的Timer需Reset才能复用,单次延迟可用更简洁的time.After。
-
不用map而用布隆过滤器是因为内存更省:上亿字符串查重时,map需几百MB,布隆过滤器仅几MB,代价是允许极小误判但绝不漏判,适合前置过滤如消息去重、URL去重等。
-
使用zap等结构化日志库统一Golang微服务日志格式,通过Filebeat采集日志并经Kafka缓冲后送入Elasticsearch存储,结合Kibana实现集中查询与可视化分析,同时注入trace_id、service_name等字段支持链路追踪与多维筛选,构建高效、可扩展的日志聚合体系。
-
Go语言虽无语法级装饰器,但可通过高阶函数(如func(http.Handler)http.Handler或泛型func(T)R)实现等效功能;HTTP中间件需正确传递响应参数并显式调用next.ServeHTTP(w,r),通用装饰器需注意泛型约束、并发安全与性能开销。
-
json.Marshal仅序列化首字母大写的导出字段,小写字段被忽略;需改名或用jsontag控制,omitempty跳过零值,"-"完全忽略,time.Time默认RFC3339字符串,加stringtag可输出带引号字符串,时间戳需自定义MarshalJSON。