-
Golang的net/rpc包可实现远程过程调用,需定义符合规则的服务方法和数据结构;2.服务端注册实例并监听HTTP端口,客户端通过Dial连接并调用远程方法;3.异常处理需关注网络错误、超时及服务端返回错误,建议设置连接与调用超时;4.默认使用gob编码,不支持跨语言,适用于轻量级内部通信。
-
sync.Once比手写双重检查更可靠,因其内置原子操作与互斥锁组合,天然解决内存可见性、指令重排和竞态问题,避免nilpanic、未初始化对象返回等错误,且性能优、行为稳定。
-
Go1.16起ioutil.TempFile被弃用,应改用os.CreateTemp;二者签名一致,返回(*os.File,error),且CreateTemp默认权限0600更安全;需注意临时文件清理,避免泄漏。
-
工厂函数返回接口类型时,必须确保所有实现完整满足接口契约,否则编译失败;应先定义接口、用静态检查验证实现,稳定方法签名,避免硬编码和panic,合理注入依赖,并明确声明线程安全性。
-
HTTP客户端请求失败时,err不一定代表网络断开;4xx/5xx状态码下err为nil,需检查resp.StatusCode;真正需重试的是net.OpError、context超时等底层错误,且须保障幂等性。
-
Go的main包虽不可被其他包导入,但可通过gotest*.go同时编译主文件与测试文件,并在packagemain下直接调用内部函数进行单元测试;关键在于测试函数命名规范(TestXxx)和参数类型(*testing.T)。
-
Go程序需通过Docker官方SDK(github.com/docker/docker/client)调用DockerEngineAPI获取容器状态,初始化时注意DOCKER_HOST和权限;ContainerList默认只返回运行中容器,需All:true;Events()支持实时监听start/die等事件,比轮询更高效。
-
gotoolcompile-gcflags="-m-l"用于查看变量逃逸分析结果,核心是理解编译器为何将变量分配到堆上:当值生命周期超出当前栈帧(如返回局部变量指针、赋给全局变量、闭包捕获、接口参数传入等)即触发逃逸;-l禁用内联以避免干扰判断;输出含“escapestoheap”或“movedtoheap”才表示真实逃逸,“leakstoheap”则更严重;高频小对象逃逸会加剧GC压力。
-
RedisStreams是Go中最实用的轻量级分布式队列方案:支持消费者组、ACK、水平扩展;需注意XADD限长、XGROUP预创建、XCLAIM处理pending消息。
-
多module适用于服务分层明确、可复用组件、独立部署单元等场景,通过合理划分项目结构(如domain、pkg、cmd分离),利用replace指令管理本地依赖,并借助接口抽象与依赖注入避免循环依赖,提升大型Go项目的维护效率与模块解耦能力。
-
Go读CSV中文乱码因标准库仅支持UTF-8,需用golang.org/x/text/encoding/simplifiedchinese.GBK.NewDecoder()将GBK字节流解码为UTF-8再交由csv.NewReader处理,写CSV反向编码同理。
-
Go项目在Jenkins上失败主因是Agent端Go环境未正确配置:需手动安装官方Go、显式设置GOROOT/GOPATH/GOCACHE并验证权限与版本兼容性。
-
使用replace指令可让Go模块依赖指向本地路径。先通过gomodinit初始化模块,再在go.mod中添加replacegithub.com/yourname/somelib=>../somelib,确保本地库有go.mod文件,最后用golist-mall验证替换生效,构建时即可加载本地代码。
-
首先安装Go并配置环境变量,再安装VSCode及其官方Go扩展,接着通过命令面板安装gopls、delve等工具,然后创建项目并初始化gomod,在.vscode中配置launch.json以支持调试,最后启用保存自动格式化即可完成开发环境搭建。
-
Go中无通用方案保证goroutine顺序执行;WaitGroup仅等待全部完成而不控制内部时序;需链式依赖时应使用channel传递数据或状态。