-
Go语言使用json.Unmarshal解析JSON时,若结构体字段为空,通常因字段未导出或缺少JSON标签导致;需确保字段首字母大写并正确设置json标签。
-
Go微服务分布式追踪需确保trace_id在HTTP/gRPC/消息队列间透传:HTTP须用W3C标准propagator注入提取;gRPC须用otelgrpc拦截器并处理tracestate;日志需注入spancontext三元组且字段名匹配采集器约定。
-
声明指针数组需使用[]*Type格式,如varptrArray[3]*int;通过取地址符&将变量地址赋给指针元素,如ptrArray[0]=&x;访问时需解引用*ptrArray[0]获取值,修改则直接赋值*ptrArray[1]=25;动态创建可结合make与循环,注意避免nil解引用和悬空指针,确保指针正确指向有效内存。
-
Go禁止指针算术运算是因内存安全、GC可靠性、类型安全和平台一致性等根本原因;日常应优先用索引、range或encoding/binary等安全方式,仅在极少数系统级场景谨慎使用unsafe.Pointer。
-
Go中数组指针声明为*[N]T,初始化需取固定长度数组地址,解引用后可原地修改原数组,支持索引和len()但不可用append(),适用于固定大小缓冲区的零拷贝场景。
-
直接用OpenTelemetryGoSDK就够了,因其已提供生产就绪的tracing实现,覆盖span管理、上下文传播、采样和导出等全部核心能力,避免重复造轮子踩坑。
-
K8s的sessionAffinity:ClientIP失效主因是流量路径中IP被SNAT或Ingress/云LB二次转发掩盖;实操需绕过Ingress直连ClusterIP、确认kube-proxy模式、合理设timeoutSeconds(推荐10800),并应用层用Cookie+Redis补足会话保持。
-
必须确保map已初始化且反射值可寻址:nilmap需先用reflect.MakeMap初始化,key/value类型须严格匹配并显式Convert,struct字段需FieldByName后检查CanAddr和CanSet。
-
不能用time.Ticker实现令牌桶,因其仅支持固定节奏发放令牌,无容量限制与预存能力;真正的令牌桶需支持突发流量缓冲、恒定填充速率及超限拒绝,故须自行维护带容量和时间戳的状态。
-
json.Marshal默认不处理私有字段、不支持循环引用、nilslice/map输出null、time.Time转RFC3339字符串——均为设计选择;字段需首字母大写才导出,tag格式须正确,nil指针需omitempty防panic。
-
最简可用GoCI流程需用actions/setup-go配置Go环境并显式启用GO111MODULE=on;必须先checkout再setup-go;含cgo需设CGO_ENABLED=1;避免冗余gomoddownload;交叉编译需指定GOOS/GOARCH;发布需permissions:contents:write及正确标签引用。
-
串行调用
在用go编写web/rpc服务器的时候,经常会出现需要对下游多 个/组 服务调用rpc(或者其他比较耗时的操作)的情况。按照自然的写法,比如对下游有ABC三个调用,串行顺着写,就总共要花费
-
channel
首先明确一下channel的作用:用于go协程间的通信。
go语言最大的特点就是支持高并发:goroutine和channel是支持高并发的重要组成部分。
单纯地将函数并发执行是没有意义的。函数与函数间
-
日常项目中,读取各种配置文件是避免不了的,这里介绍一个能读取多种配置文件的库,viper
viper读取ini文件
config := viper.New()
config.AddConfigPath("./conf/") // 文件所在目录
config.SetConfigName("b") /
-
字符串拼接在 golang 里面其实有很多种实现。
实现方式
直接使用运算符
func BenchmarkAddStringWithOperator(b *testing.B) {
hello := "hello"
world := "world"
for i := 0; i &