-
合法基准测试函数需命名为BenchmarkXxx,签名固定为funcBenchmarkXxx(b*testing.B),被测逻辑置于b.ResetTimer()之后,用b.ReportAllocs()统计内存分配,避免循环内非必要操作。
-
Gotime包解析失败常静默返回零值,因布局须严格匹配参考时间"2006-01-02";格式化应优先用RFC3339等预定义常量;时区须显式指定,避免依赖默认本地时区。
-
Go微服务负载均衡需手动设计客户端路由,核心是维护健康实例列表并按轮询或加权轮询策略选节点;需结合服务发现、线程安全计数、平滑加权及集成HTTP客户端实现。
-
指针赋值复制地址,使多个变量共享同一内存,修改相互影响;值拷贝创建独立副本,互不干扰。1.指针赋值如pb:=pa,pb和pa指向同一变量,修改*pb影响原值;2.值类型如int、struct赋值时深拷贝,如p2:=p1后修改p2不影响p1;3.大结构体建议用指针传递,避免性能开销,如函数参数*Person;4.切片和map为引用类型,赋值时复制内部指针,仍共享底层数组或哈希表,修改会同步。理解“复制的是地址还是数据”是关键。
-
Go反射只能访问导出字段,需传结构体地址并调Elem(),Field(i)按索引取值须校验NumField(),FieldByName更安全但需检查IsValid()和CanInterface(),嵌入与指针字段需手动处理,避免nil解引用,性能差且易出错,仅适用于低频场景。
-
crypto/elliptic不能直接加密,仅支持密钥协商和签名;它提供点乘、密钥生成等底层数学操作,加密需结合crypto/ecdsa、curve25519或AES自行实现ECIES。
-
net.Dial("ip4:icmp",...)报"operationnotpermitted"是因ICMP需rawsocket,Linux/macOS需root或cap_net_raw,Windows需管理员权限;应改用golang.org/x/net/icmp并设连接级deadline。
-
runtime.NumGoroutine()返回当前程序中正在运行或处于等待状态的goroutine总数,包括用户创建和runtime内部协程,是瞬时、无锁、低开销的整数快照。
-
直接用os.SameFile不行,因其仅判断inode或volume+index是否相同,不比较内容;同步需内容一致,故应结合大小预筛与分块哈希(如1MB块取首尾)提升效率。
-
channel必须初始化才能使用:声明chanint类型变量未用make初始化,运行时panic报「sendonnilchannel」;Go禁止对nilchannel发送或接收数据。
-
字符串与数字转换可用strconv包实现,如Atoi、Itoa、ParseInt、FormatInt等函数,需注意错误处理和类型范围。
-
一个典型的多包Go项目应合理划分目录结构,如cmd/存放主程序入口,internal/存放私有包,pkg/存放可复用公共库,配合go.mod进行依赖管理;通过import导入包并使用大写字母导出标识符,利用gobuild支持的多种编译方式(如-race、-ldflags、交叉编译等)优化构建过程,结合Makefile或脚本统一流程,确保项目可维护性和工程效率。
-
Go语言没有稳定可靠的goroutineID获取方式,所有解析runtime.Stack()字符串的方法均不可靠、低效且易失效;应改用request_id上下文传递、GoroutineProfile监控等正确替代方案。
-
数组是值类型,传参时整块复制;切片传的是含指针、len、cap的结构体,共享底层数组。[3]int与[4]int类型不同,而[]int无长度限制,可接收任意长度切片。
-
非空接口通过iface结构中的tab指针(指向itab,含类型信息和方法地址)和data指针(指向具体数据)实现多态;空接口eface仅含_type指针和data指针,无方法调用。