-
GoLand提示失效需检查GOROOT和GoProxy配置,VSCode中gopls失败常见于版本不兼容、缺少go.mod、GO111MODULE=off或vendor未启用;自定义类型无提示多因未保存、跨module或索引未触发。
-
能,iota定义的常量是编译期确定的整型常量,支持算术运算(+、-、*、/、%)和位运算(<<、&、|、^、&^),但须满足编译期可求值与类型兼容规则。
-
bufio.Scanner默认缓存整行易致内存爆炸,遇超长行或大文件可能触发ErrTooLong或OOM;适合行短可控文本,非GB级日志场景;若必须使用,应先调用scanner.Buffer(make([]byte,64*1024),1<<31)。
-
在Go的html/template中,使用{{template"name"}}语法引入子模板时,默认不会自动继承当前作用域的数据;必须显式传入上下文(如.)才能使变量在被包含模板中可用。
-
Goflag包存在四大隐式陷阱:一是flag.Parse()必须在所有flag定义之后且仅调用一次;二是StringSlice不自动合并多次参数,需自定义Value类型实现追加;三是自定义类型须完整实现flag.Value接口(Set和String方法);四是help文本硬编码、不可配置,需手动拦截-h/--help并定制输出。
-
Go函数返回错误的标准写法是error必须作为最后一个返回值,类型为error接口,成功时返回nil;应使用errors.New或fmt.Errorf(%w包装)构造错误,禁止忽略或裸panic,自定义错误需实现Error()方法。
-
TLS是微服务通信安全基础,Golang原生支持;HTTP可单向认证(ListenAndServeTLS),gRPC天然支持;mTLS需双向证书校验,须注意证书有效期、域名匹配与私钥保护。
-
Go中struct字段导出的唯一规则是首字母大写:大写开头(如Name)可被外部包访问,小写或以下划线开头(如name、_id)均不可导出;JSON标签等不影响导出性,嵌套字段需逐层满足导出条件,且无法通过指针绕过限制。
-
append扩容时会重新分配底层数组,新切片指向新地址,旧切片不再共享数据;预分配cap可避免多次realloc提升性能;扩容复制为浅拷贝,引用类型元素仍指向同一底层结构。
-
Go的map默认非并发安全,多goroutine读写会触发panic;sync.Map适用于高读低写场景,但不支持遍历且无泛型;推荐用泛型SyncMap+RWMutex封装以兼顾类型安全与并发控制。
-
Go语言禁止隐式类型转换,必须显式用T(x)语法转换;字符串与数值互转需用strconv包;结构体等复合类型间不可随意强转,仅支持特定安全转换如[]byte与string。
-
gRPC接口版本管理依赖proto包名、模块路径和生成代码命名空间三者协同实现静态隔离;必须为每个版本设置带版本号的proto包名、独立目录及显式go_package选项。
-
应按业务域而非技术层划分包结构,如internal/user、internal/order,每包内含handler.go、service.go等;用internal限制可见性;service依赖接口而非具体实现;模块边界依限界上下文持续演进。
-
向已关闭的channel发送数据会立即引发panic;Go语言规范明确规定,对关闭后的channel执行send操作是非法的,运行时将触发致命错误。
-
Go语言无全局异常捕获,panic仅限当前goroutine;统一错误处理核心是构造、传播、分类与响应策略:用fmt.Errorf("%w")链式包装、注入traceID等上下文,HTTP用中间件统一封装错误响应,goroutine错误需显式收集(如errgroup),业务错误应定义为可识别类型而非字符串匹配。