golang
已收录文章:116篇
-
使用proto3定义gRPC服务,通过message和service定义数据与接口,生成Go代码实现高效通信。435 收藏
-
调整GOPATH和缓存设置可显著提升Golang编译速度。1.精简GOPATH路径并迁移至GoModules以优化依赖查找;2.设置GOPROXY为https://goproxy.io,direct加速模块下载;3.利用goenv查看或修改GOPATH、GOPROXY;4.启用编译缓存并避免频繁清理;5.使用gobuild-x、gotooltrace等工具诊断编译瓶颈;6.升级Go版本、使用SSD、增加CPU与内存资源;7.避免cgo、拆分代码包、启用并发编译;8.通过Makefile、CI/CD或脚本自432 收藏
-
深拷贝需创建完全独立的副本,避免原对象被修改。Go中通过手动复制、Gob序列化或第三方库实现,注意循环引用、不可导出字段及性能开销,选择方法需权衡控制粒度、通用性与便捷性。426 收藏
-
多个goroutine通过指针访问共享变量时可能引发数据竞争;2.Go通过原子操作和互斥锁实现并发安全;3.指针直接操作内存需配合同步机制避免竞态条件。422 收藏
-
使用Go的channel和goroutine实现整数处理流水线:生成整数→平方→过滤大于100→输出结果,各阶段通过channel串联,每个阶段函数接收输入channel并返回输出channel,形成可组合、高效的数据处理链。421 收藏
-
在Kubernetes中为Golang服务配置探针需设置Liveness、Readiness和Startup探针:1.Liveness探针通过/healthz接口检测服务健康,失败后重启容器;2.Readiness探针通过/ready接口判断服务是否就绪,失败后停止流量接入;3.Startup探针用于启动耗时较长的场景,防止早期误判。各探针需合理配置initialDelaySeconds、periodSeconds、timeoutSeconds和failureThreshold参数,避免影响服务稳定性。探409 收藏