golang
已收录文章:14174篇
-
Go语言通过encoding/csv包高效处理CSV文件读写。首先使用os.Open打开文件,结合csv.NewReader读取数据,可调用ReadAll()一次性读取或Read()逐行读取以节省内存;写入时用os.Create创建文件,csv.NewWriter写入数据,需注意调用Flush()确保数据落盘;支持自定义分隔符,如设置Comma=';'处理分号分隔文件,适用于欧洲格式CSV,广泛用于配置、报表等场景。261 收藏
-
扇出模式通过将任务分发给多个goroutine并发执行以提升效率。在Golang中,使用channel和goroutine实现:主goroutine发送任务到jobschannel,多个workergoroutine接收并处理任务,结果返回resultschannel。为避免goroutine泄露,需关闭jobschannel,使用sync.WaitGroup等待所有worker完成,并可设置超时机制。worker数量应根据CPU核心数、任务类型(CPU或I/O密集型)和基准测试调整,通常从CPU核心数开261 收藏
-
答案是使用索引或range遍历指针数组并解引用获取值。声明如[3]int,初始化后通过for循环访问每个指针元素,用解引用获取指向的值,例如fori:=0;i<len(ptrArray);i++{fmt.Println(*ptrArray[i])}。261 收藏
-
使用结构化日志库(如zap)、输出日志到stdout、集成FluentBit或Promtail采集、结合Loki与Grafana实现轻量级聚合,并通过OpenTelemetry统一观测性数据,是Golang云原生日志聚合的核心实践。261 收藏
-
正文 本文包括两部分,一部分是源码解读,另一部分是对zap的增强。 由于zap是一个log库,所以从两方面来深入阅读zap的源码,一个是初始化logger的流程,一个是打一条log的流程。 初始化Logger za260 收藏
-
客户端流式RPC:与服务端流式RPC相反,客户端不断的向服务端发送数据流,而在发送结束后,由服务端返回一个响应。 情景模拟:客户端大量数据上传到服务端 新建proto文件 新建client_stream.prot260 收藏