-
Go中对比函数性能最标准方式是使用gotest的基准测试机制,需以Benchmark开头、接收*testing.B参数、置于_test.go文件,并在b.N控制的循环中调用被测函数。
-
nil检查必须在解引用前发生,因Go中对nil指针解引用会直接panic且无法用error捕获;所有可能为nil的变量在访问字段或调用方法前须显式检查,尤其注意接口、切片、map等零值语义差异及interface{}和泛型中的nil判断陷阱。
-
在Go中创建结构体实例时,应根据是否需要指针、初始化需求及性能考量,合理选择var(值类型)、new(T)(零值指针)或&T{}(可初始化的指针),三者语义不同,不可互换。
-
滥用panic本质是错误处理权错配;该用error而非panic的核心判断是调用方能否/应否响应失败:能则返回error,不能且继续执行会致状态污染才考虑panic。
-
net.DialTimeout更适合端口扫描,因其可精确控制连接超时(如500ms),避免系统默认长超时阻塞并发;需合理设值防误判,配合WaitGroup与令牌桶限流,并通过类型断言准确区分open/filtered/closed状态。
-
Goerrors包仅支持基础错误创建,错误链、堆栈和上下文需用fmt.Errorf配合%w包装;errors.New适用于静态无参错误(如包级常量),fmt.Errorf用于格式化、变量插入或错误包装;errors.Is和errors.As仅对%w包装的错误有效,手动errors.Unwrap极少使用,因Is/As已自动递归处理错误链。
-
interface{}不能作为泛型约束,因其不提供任何方法或操作保证;正确做法是使用带方法的接口、comparable或带~前缀的底层类型联合约束,且约束名须大写导出。
-
httptest包提供两种核心测试方式:NewServer用于集成测试完整HTTP流程(启动真实本地服务器),NewRequest+NewRecorder用于单元测试单个handler(内存中无网络调用)。
-
context用于控制goroutine生命周期和传递取消信号;必须传入context.Context的场景包括调用显式接受该参数的函数(如QueryContext)、HTTPhandler中发起下游请求、启动需受控的子goroutine等。
-
用channel做任务流转更可控,因其具备缓冲、阻塞语义和显式数据契约,可限流、等待完成、统一错误处理,并支持日志、重试、超时等扩展逻辑。
-
Go反射无法直接调用结构体的函数字段,需先通过Field.Interface()获取原生函数再调用;结构体字段不可动态增删,应使用嵌入接口实现行为注入;反射调用方法时需确保receiver可寻址;含func字段的结构体不可序列化,须手动剥离或用DTO传输。
-
Facade是一种通过结构体封装多依赖调用、提供简洁接口的设计模式,Go中无需类继承即可实现,核心是降低调用方认知负担,关键在于统一超时、错误处理与依赖注入,避免沦为上帝对象。
-
GOMAXPROCS无效或变慢的根本原因是它仅限制同时运行的OS线程数,而非协程数;盲目增大在I/O密集型场景会加剧线程切换开销,且需在main开头设置才生效,误设位置或动态调整反致调度异常。
-
Go中map[string]struct{}的字段不可修改,因map值不可寻址,底层扩容可能导致内存位置变化,故禁止取地址以避免悬垂指针。
-
使用net/url包可安全解析和构建URL。1.用url.Parse()提取Scheme、Host、Path等字段;2.通过Query()获取参数并用Get/Set/Add操作值,Encode()自动编码;3.手动构建URL需设置Scheme、Host、Path及RawQuery;4.ResolveReference()合并基础URL与相对路径,适用于重定向处理。掌握这些方法可高效处理各类URL操作。