golang
已收录文章:13659篇
-
Go中通过指针操作结构体可实现字段修改和性能优化,使用&取地址、解引用,但访问字段时可直接用点号,编译器自动处理解引用,如ptr.Name等价于(ptr).Name;传指针给函数能避免复制并修改原值;创建指针可用&Person{}或new(Person),前者可初始化,后者得零值。480 收藏
-
Go并发中需用defer+recover捕获panic,通过errorchannel传递错误,结合context处理超时取消,并利用errgroup统一管理多协程错误,确保错误不遗漏、panic不扩散。156 收藏
-
使用Golang构建微服务时,gRPC基于HTTP/2和ProtocolBuffers实现高效通信;2.多服务间需定义清晰的proto接口并分文件管理;3.通过protoc生成Go代码,可将多个服务注册到同一gRPCServer;4.服务间通过gRPC客户端调用,如Order服务调用User服务验证用户;5.生产环境应启用TLS、设置超时、使用拦截器及服务发现机制;6.建议统一管理proto文件,保持接口契约一致性和可维护性。134 收藏
-
Go语言通过goroutine和channel实现并发,利用HTTPRange头分块下载文件,结合HEAD请求获取文件信息,按字节范围并发下载多个片段,使用信号量控制协程数量,每块独立下载后合并,并支持错误重试机制。146 收藏
-
ioutil.ReadFile适用于小文件读取,但大文件需用bufio.Scanner逐行处理以节省内存;Go1.16后推荐使用os.ReadFile替代ioutil.ReadFile,临时文件操作建议迁移到os.MkdirTemp和os.CreateTemp。481 收藏
-
通过Helm与Golang结合实现多环境部署,采用charts/存放公共模板,environments/下分dev、staging、prod配置文件,利用--values指定不同环境变量并注入容器环境变量,Golang程序通过os.Getenv读取配置,结合CI/CD根据分支或标签自动部署至对应环境,提升发布安全性与可维护性。273 收藏