-
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判断
-
表驱动测试是Go中最推荐的单元测试组织方式,通过结构体切片集中定义测试用例并循环执行,提升可读性、可扩展性与可维护性。
-
gRPC要求显式import依赖的.proto文件,路径相对于--proto_path而非当前文件;多文件需一次性传给protoc生成代码;跨文件复用需避免循环引用和重复定义;包名由go_package等option统一控制。
-
GoLand中DatabaseNavigator连接失败主因是驱动未手动安装及URL缺少SSL禁用参数;表不显示需检查schema/权限并手动刷新;SQL执行需绑定数据源;结构变更后须右键单表刷新元数据。
-
最推荐使用goldmark库将Markdown转为HTML;它符合CommonMark标准、安全可配置、性能好,需显式注册extension.Table等扩展以支持表格和任务列表,并建议全局复用实例以提升Web服务性能。
-
最简安全下载需用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支持捕获组,提前检查目标路径存在性并处理跨文件系统场景。