-
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指针,无方法调用。
-
Go写二进制文件须用binary.Write、io.Write或[]byte操作,禁用字符串转换;binary.Write要求结构体字段导出、字节序明确、不支持map/slice;io.Write需检查返回值;变长数据需手动编码长度前缀。
-
t.Skip()在Golang测试中用于条件跳过,适用于环境依赖、资源密集、跨平台、未完成功能等场景,避免测试噪音。它与t.Fail()/t.Fatal()的本质区别在于:跳过表示测试不适用而非失败,不计入失败数,不影响CI/CD结果。最佳实践包括使用辅助函数、TestMain、环境变量、构建标签、清晰消息和定期审查,以保持测试集清晰可维护。
-
Go1.3起默认采用连续栈:初始栈2KB,扩容时复制旧栈并修正指针,消除分段栈的检查开销与GC扫描难题,但带来复制停顿;栈大小动态调整,上限1GB,超限仍panic;defer/recover在扩容中可靠,因运行时重定位_defer结构;监控StackSys可定位栈内存异常。
-
Go的http.Header非线程安全,并发读写会panic;Set/Add语义不同:Set覆盖、Add追加;多值字段应使用Values()而非Get()后切分;Header.Clone()可深拷贝隔离数据,但不解决并发安全。
-
多层指针是指向指针的指针,用于修改指针本身或与Cgo交互等场景。例如p2可访问原始值10;函数changePointer通过int修改外部指针指向为20。需注意空指针、可读性差及过度嵌套问题,建议仅在必要时使用。
-
syntax="proto3";、optiongo_package和字段编号是Protobuf编译期强制契约:前者必须独占首行且不可省略或错写,go_package决定Go包路径和生成位置,字段编号一旦发布不可变更,否则导致wire不兼容与解码错位。
-
Homebrew官方核心仓库审核严格,多数Go工具因不稳定、不流行或构建方式不符而无法入库,故开发者需自建Tap:即GitHub上名为homebrew-xxx的公开仓库,仅托管Ruby编写的Formula文件,描述从指定GitTag拉取源码、用gobuild构建、安装到bin的过程;用户通过brewtapusername/repo&&brewinstallusername/repo/tool使用。
-
gomodgraph输出全量有向边导致难以阅读,应结合grep过滤、导出文本搜索、避免vendor模式,并用golist-m-json或gomodwhy辅助分析实际依赖关系。
-
select会阻塞,除非有case立刻就绪;它挂起goroutine直到至少一个channel操作可立即完成,无default时全阻塞,nilchannel永不就绪,多case同时就绪则随机执行。