golang
已收录文章:341篇
-
vendor目录用于本地化依赖管理,Go编译器优先从该目录加载依赖,实现版本锁定与构建隔离;2.通过gomodvendor命令基于go.mod和go.sum生成vendor目录,包含第三方包及modules.txt记录;3.构建时自动或通过-mod=vendor参数启用vendor依赖,提升离线构建稳定性;4.vendor虽增强可靠性但增加仓库体积,官方现推荐以GoModules为主,仅在离线部署等场景使用vendor。131 收藏
-
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 收藏