golang
已收录文章:90篇
-
在Go语言中传递大对象时应使用指针传递以避免内存拷贝,具体做法包括:对大结构体使用指针传参、返回大对象时返回指针或通过参数修改原对象、为大结构体定义指针接收者方法、注意指针可能导致的逃逸和GC压力,并合理使用sync.Pool缓存对象,同时需知slice、map、string等引用类型本身轻量无需额外指针包装,综合这些技巧可显著提升性能且保持代码清晰。187 收藏
-
黄金文件是Go中用于验证复杂输出的预存预期结果文件,通常以.golden为扩展名。测试时将实际输出与之对比,确保一致性。首先编写测试函数生成输出,通过flag.Bool("-update")控制是否更新黄金文件,首次运行生成文件后,后续测试自动比对。建议将黄金文件存于testdata目录下,避免编译。针对时间戳等动态内容,需标准化输入或预处理输出。可借助go-cmp或gotestyourself库提升效率。核心是建立可靠更新机制,保障团队对正确输出的共识。187 收藏
-
Go语言中可用函数式编程实现策略模式,通过定义SortStrategy函数类型并结合一等函数,使排序算法可动态切换;具体通过Sorter结构体持有策略,支持运行时替换算法,如使用AscendingSort、DescendingSort或匿名函数作为策略,实现灵活、解耦的排序逻辑。186 收藏
-
选择FluentBit+Golang构建云原生日志收集器,因Go插件开发更简单快速,适合非极端性能场景。1.FluentBit是轻量级日志收集器,支持多种输入输出插件;2.Go插件基于CGO,可实现灵活扩展,适合开发中间件和适配器;3.开发步骤包括定义入口点、实现逻辑、编译为.so动态库;4.Kubernetes中可通过自定义镜像或ConfigMap挂载部署插件;5.调试需关注日志输出、线程安全、资源释放及交叉编译问题。181 收藏
-
Go语言凭借Goroutine实现高并发处理,单个Goroutine仅2KB栈空间,配合GMP调度模型降低系统开销,结合channel实现安全通信,使微服务可轻松应对数万并发连接;其静态编译特性生成小巧、独立的二进制文件,启动迅速、内存占用低,容器镜像常小于20MB,显著提升部署效率;加之gRPC-Go、Gin、Prometheus等生态工具完善,全面支持服务通信、监控与追踪,形成高性能、易维护的微服务解决方案。174 收藏
-
服务定位器模式通过全局注册表解耦服务获取与创建,适用于Go中数据库、日志等全局服务访问,简化依赖传递,但存在隐藏依赖和生命周期管理问题,建议结合接口键、安全获取及初始化限制优化使用。160 收藏