-
JSON.Unmarshal传指针还是传值?传值会失败,必须传指针。Go的json.Unmarshal内部靠反射修改目标变量的内存内容,如果传入的是值(比如user而不是&user),它只能修改栈上的一份副本,原变量不受影响。常见错误现象:json.Unmarshal([]byte(`{"name":"a"}`),user)后user.Name仍是空字符串,无报错但无效果值类型(如struct、int、string)必须取地址传入;引用类型(如*struct、[]int、
-
Go语言通过ParseMultipartForm解析表单并设内存上限,再用FormFile按name获取文件,配合os.Create保存,需注意文件校验、路径安全与大文件处理。
-
使用标准库log记录错误并结合errors包增强上下文,生产环境推荐zap等结构化日志库,统一封装实现高效错误追踪。
-
go.mod应按发布/复用意图设在各独立模块根目录,如主应用cmd/api、可导出组件pkg/storage;internal下不可设模块;import路径须严格匹配module声明值,跨模块依赖需显式gomodtidy或replace。
-
应显式构造带超时的*http.Client,避免使用http.Get;正确用url.Values拼接参数并SetHeader;禁用或自定义重定向逻辑;复用连接需配置Transport连接池;务必检查resp.StatusCode和resp.Body。
-
modulepath是模块的唯一标识,出现在go.mod中,如example.com/myproject;packagepath由modulepath加上子目录构成,表示具体包的位置,如example.com/myproject/utils,用于import。
-
sync.Mutex在高并发下易成瓶颈,因其排他性导致读操作串行化、调度开销上升;RWMutex仅适用于读多写少且读操作真正只读的场景;atomic适用于基础类型单变量操作,性能更高但功能受限;锁粒度细化(如分片锁)可显著提升QPS,但需权衡分片数与资源消耗。
-
Go语言通过range、闭包和channel实现灵活的迭代器模式。首先,range可遍历切片、map和channel,支持索引值或键值对访问;其次,利用闭包封装状态可创建惰性求值的函数式迭代器,如斐波那契数列生成器;接着,通过定义Next、Value等方法可实现面向对象风格的迭代器结构体,便于错误处理与泛型扩展;最后,结合goroutine与channel能构建并发安全的迭代器,适用于异步数据流处理,如文件目录遍历场景。
-
在Go语言中,通过typeNewTypeUnderlyingType声明的新类型拥有独立且为空的方法集,即使底层类型已定义方法,新类型也无法直接调用——这是Go类型系统的核心设计原则。
-
Go可变参数通过...语法实现,本质是接收零或多个同类型值并以切片处理;必须为最后一个参数,调用时可用...展开切片,支持与固定参数混合使用。
-
Consul客户端初始化失败主因是导入错误包或传nil配置;必须用"github.com/hashicorp/consul/api"且配置Address;服务注册后不可见常因缺失健康检查;Health().Service默认只返回通过检查的服务;Docker中需避免127.0.0.1网络问题。
-
Go语言基础类型共5种:bool、整数类、浮点类、复数类、string;其中bool仅含true/false且不与0/1互转;整数类分有符号/无符号及byte(uint8)、rune(int32)别名;浮点类为float32/float64,比较须用math.Abs避免==。
-
Go中无引用类型,但指针等可模拟引用语义;必须用T而非T的场景包括:修改原变量、避免大结构体拷贝、实现仅在T定义的方法集的接口。
-
Go切片是对底层数组的轻量级引用,由指针、长度(len)和容量(cap)三部分构成;创建方式有字面量初始化、make函数及截取;len为当前元素数,cap为起始位置至数组末尾的总元素数;支持修改、append追加(可能扩容)、共享底层数组(有意外修改风险),需copy避免;常用操作包括删除元素、截取、清空、判空等。
-
go_proto_library生成的.pb.go文件为什么总找不到包?根本原因是protoc生成代码时默认用package声明匹配.proto文件的package,但Go的import路径和磁盘路径必须一致,而很多人把.proto放在api/下却希望生成到github.com/x/y/api,结果Go编译器只认路径,不认package声明。实操建议:用--go_out=paths=source_relative:./让protoc按.pro