-
因为未设置种子,rand默认使用固定种子0,导致每次运行结果相同;应改用rand.New(rand.NewSource(time.Now().UnixNano()))并避免全局状态污染。
-
结构体指针通过引用传递实现高效数据共享与修改。Golang中结构体默认值传递,复制大对象开销大,使用指针可避免此问题;函数需修改原结构体时必须传指针,因值传递仅操作副本。Go简化指针访问,支持直接用ptr.Name而非(ptr).Name。方法若需修改接收者,应使用指针类型,否则作用于副本。常见场景包括:工厂函数返回Type、嵌套结构体用指针减少内存占用、接口实现中需修改状态时。掌握结构体指针关键在于理解其性能优势与数据共享机制。
-
Go标准库在Windows下用IOCP但不暴露裸接口,因其调度模型(GMP)与IOCP线程池不兼容,所有I/O被runtime.netpoll封装以统一跨平台行为。
-
atomic.StorePointer不能存任意指针,因要求指针指向GC可追踪的堆内存,栈地址或uintptr中转会引发悬垂引用或panic。
-
首先定义任务结构体并通过channel传递任务,创建带缓冲的channel存放任务;然后启动多个工作协程从channel中并发读取并执行任务,直至channel关闭,实现高效的任务分发与调度。
-
Windows安装Go只需运行MSI包并重启终端即可;常见问题为PATH未生效、GOPATH误配或未初始化模块,goversion和gorun成功即环境已就绪。
-
Go事务不会自动回滚,必须显式调用tx.Rollback()或tx.Commit(),否则事务持续挂起导致锁表、阻塞查询;推荐用defer+committed标志位精准控制回滚,避免重复回滚报错。
-
Go1.14+默认不自动使用vendor目录,需显式指定-mod=vendor;gomodvendor可能遗漏隐式依赖,应清理后配合gomodtidy重生成;离线构建必须设置GOPROXY=off、GOSUMDB=off,并确保根目录go.mod和go.sum完整。
-
goroutine泄漏、HTTP客户端未复用、错误处理不落地是并发爬虫三大核心问题:需用信号量或缓冲channel限并发,全局复用并配置http.Client,区分错误类型实现精准重试。
-
不能用http.Server做设备长连接接入层,因其请求-响应模型不支持服务端主动推送、心跳保活和低开销通信,硬套会导致TCP频繁建连断连、handler同步阻塞排队、JSON解析触发高频GC。
-
Go中无传统指针悬挂但存在逻辑悬挂:指针有效而数据过期;逃逸分析自动堆分配保障安全,但易引发隐式共享、循环变量复用等逻辑问题。
-
strings.Builder扩容公式为cap×2+新增长度,非固定翻倍;Grow(n)确保len+n≤cap,不强制分配n字节;初始cap为0,扩容策略优先满足本次写入,更紧凑但需合理预估总长。
-
蓝绿部署通过双环境切换实现零停机回滚,结合Nginx或Kubernetes快速切流;2.Kubernetes基于版本标签滚动更新,利用kubectlrolloutundo快速回退;3.Go服务暴露/healthz健康检查接口,配合liveness/readiness探针实现自动恢复;4.使用Consul等配置中心支持热reload,避免因配置错误触发回滚。Go应用需结合版本控制、监控告警与自动化机制,确保发布与恢复可靠性。
-
Go语言通过反射可动态获取结构体方法,核心是使用reflect.TypeOf获取类型对象,再调用NumMethod和Method遍历方法;需注意值接收者与指针接收者差异:值类型只能访问值接收者方法,而指针类型可访问两者;通过reflect.Method可获取方法名、类型签名及函数值,进而实现动态调用。
-
bufio.Scanner默认单行上限64KB,超长会panic;应显式调大缓冲区或改用bufio.Reader+ReadString控制内存,及时释放行引用防OOM,避免全存切片,JSON解析优选json.NewDecoder。