-
启动子进程需设SysProcAttr实现进程组隔离,加context超时控制,用Signal(SIGTERM)优雅停止并Wait回收,跨平台需分支处理信号逻辑。
-
Jaeger客户端初始化失败:span为空或上报无数据常见现象是调用tracer.StartSpan()后得到nil,或者服务跑起来但JaegerUI里完全看不到trace。根本原因通常是tracer没正确初始化,或初始化时漏了关键配置。必须在main函数早期、任何span创建前完成jaeger.NewTracer()调用,且返回值要赋给全局tracer变量(不能只声明不赋值)采样器配置别写死const,生产环境至少用probabilistic并设Samp
-
golangci-lint安装后commandnotfound是因未加入$PATH;macOS/Linux需将$HOME/go/bin加入~/.zshrc或~/.bashrc,Windows需手动添加%USERPROFILE%\go\bin到系统Path。
-
Go字符串原生支持Unicode,问题出在外部系统交互:MySQL需utf8mb4、JSON默认转义Emoji、len()返回字节数非字符数、HTTP响应头须声明charset=utf-8。
-
指针数组是固定长度的数组,每个元素为指向某类型的指针,适合元素个数已知且不变的场景;定义方式为varptrArray[3]int,结合&取地址符初始化后可通过解引用访问值;指针切片则是长度可变的动态集合,使用make([]int,0)或字面量[]int{&a,&b}创建,同样通过*操作符获取值;二者常用于修改原数据、避免大对象拷贝及构建复杂结构;需注意指针有效性、逃逸分析机制及并发下的数据竞争问题;核心在于理解“指针存地址,操作需解引用”,根据场景选择数组或切片以提升性能与灵活性。
-
Go的http.Client本身不支持带宽限制,需通过io.LimitReader(下载限速)或包装net.Conn(全链路限速)实现;上传限速需包装req.Body;netutil.LimitListener不适用于客户端。
-
error是可预期、可恢复的业务失败结果,作为函数返回值需显式检查;panic是程序不可继续时的紧急终止机制,触发后默认崩溃goroutine,recover仅用于顶层兜底而非替代error。
-
Go语言不采用传统迭代器接口而推荐函数值形式(func()(T,bool)),因其类型安全、无状态、易组合且符合Go风格;泛型支持后更可写出类型安全的SliceIterator等工厂函数。
-
iota是Go语言编译期行级计数器,按实际赋值行序号递增(空行、注释、下划线不消耗),起始值和步长需手动偏移(如First=iota+1),同一行多常量共享同值,跨const块重置;定义位掩码必须用1是因为需确保每位独立为2的幂次,避免位运算冲突。
-
reflect.TypeOf返回的是接口类型,不是底层类型你写reflect.TypeOf(x),得到的永远是reflect.Type接口实例,不是原始类型(比如int或*string)。想拿到具体类型名或底层结构,得调用它的方法,而不是直接打印或比较。常见错误现象:fmt.Println(reflect.TypeOf(x))看起来像输出了类型,但其实是调用了String()方法——它返回的是带包路径的字符串(如"main.User"),不能直接用于类型断言或switch判断
-
最简安全下载需用http.Client设置超时,检查StatusCode,以io.Copy流式写入;带进度需分块读取并计算百分比;断点续传依赖Range头和Accept-Ranges;文件名优先取Content-Disposition,再清理非法字符防路径遍历。
-
Go1.17+官方二进制依赖GLIBC_2.18,而CentOS7自带glibc2.17,导致运行时报错;安全方案是在centos:centos7容器中编译,或禁用cgo静态链接,务必用file和ldd验证。
-
httptest.NewRequest构造请求对象无需网络调用,需正确设置method、URL、body和Content-Type;配合httptest.NewRecorder捕获响应,可断言status、header和body;路由参数需手动注入context;避免启动真实server,优先单元测试业务逻辑。
-
filepath.Walk默认遇错中断,应改用WalkDir并对os.ErrPermission返回nil继续;重命名需用ReplaceAllString支持捕获组,提前检查目标路径存在性并处理跨文件系统场景。
-
slog默认不输出DEBUG日志是因为其默认日志级别为slog.LevelInfo,Debug级别被静默过滤;需显式配置HandlerOptions.Level为slog.LevelDebug并通过slog.SetDefault()生效。