-
Go1.21+的rate.Limiter.SetLimit()可安全修改rate,但burst不变,需同比缩放;burst变更必须原子替换整个*rate.Limiter实例。
-
Go的多变量赋值(如b,a=a,b)并非逐条顺序执行,而是先求值后赋值,所有右侧表达式在左侧赋值前已全部计算完毕,从而天然避免中间状态覆盖,实现安全交换。Go中如何原子地交换两个变量:从语法糖到汇编实现Go语言支持简洁的多变量赋值语法,例如b,a=a,b可以在一行内完成两个整数的交换。这看似违反直觉——如果按“先赋b=a再赋a=b”的顺序执行,结果显然会出错。但实际并非如此:Go的多变量赋值是一个原子性操作,其语
-
Go1.18+切片扩容阈值为256,非1024;仅当len==cap时append才触发growslice;空slice首次append分配1元素空间;内存按sizeclass对齐导致碎片;预估容量比依赖自动扩容更高效可控。
-
Go的map默认非并发安全,多goroutine读写会触发panic;sync.Map适用于高读低写场景,但不支持遍历且无泛型;推荐用泛型SyncMap+RWMutex封装以兼顾类型安全与并发控制。
-
推荐用sync.Map+独立chan+context.Context实现内存级Pub/Sub:sync.Map避免并发写panic和迭代器失效,Range快照语义确保发布一致性;须封装value为struct并避免在Range中Load/Store;每个订阅绑定context防goroutine与channel泄漏。
-
Pipeline能提速3–5倍,因将多次TCP往返(RTT)压缩为一次发送与响应,省去99%网络延迟;但需严格按三步执行:调Pipeline()、链式发命令、显式Exec()触发,且每条命令结果与错误须单独检查。
-
Go使用-buildmode=c-shared编译共享库时,导出函数不能直接接收Go原生string类型;必须使用*C.char并通过C.GoString()转换,否则会因内存布局不匹配触发runtimeout-of-memorypanic。Go使用`-buildmode=c-shared`编译共享库时,导出函数不能直接接收Go原生`string`类型;必须使用`*C.char`并通过`C.GoString(
-
Go闭包捕获变量会导致内存泄漏,因闭包持有变量引用阻碍GC;正确做法是在循环体内用i:=i显式创建独立副本,确保每个闭包绑定专属值。
-
Go中WebSocket心跳需服务端启用PingHandler并每25秒发ping、客户端每30秒发JSON心跳包,双方均需超时检测(服务端45秒、客户端60秒)并主动断连,同时注意Nginx超时配置与WriteMessage并发安全。
-
使用指针返回可避免大结构体拷贝、提升性能,并支持修改原始数据。通过逃逸分析,Go能安全返回局部变量地址;基本类型指针需谨慎使用,常用于标记“空值”;当接口方法为指针接收者时,必须返回指针以满足接口实现。
-
Go中不存在安全可靠的“先检查再发送”模式,因channel关闭是单向承诺而非可探测状态;唯一安全方式是send-or-die:发送方须独占channel所有权并负责其生命周期管理。
-
购物车数据结构推荐用map[string]*CartItem配合[]string记录顺序;需统一ID类型、合并重复商品(按ProductID+SkuID判断)、删除时同步更新map和顺序切片,并用sync.Mutex保证并发安全。
-
M会被休眠回收当且仅当:未绑定LockOSThread、无运行G且队列为空、未处于系统调用、已解绑P并完成handoffp、空闲超约10ms;cgo派生的M由C侧管理,runtime不回收。
-
Go构建RESTfulJSON接口的核心是net/http包配合结构体序列化,需定义带json标签的导出字段结构体、用json.Decode解析请求体、json.Encode生成响应、正确设置Content-Type头及HTTP状态码。
-
必须自己实现net.Listener才能实现连接控制,因http.Server不暴露连接池、不提供连接列表、也不支持主动关闭单条连接,仅无条件接受conn并启goroutine处理,需通过包装Listener拦截Accept()和Close()来接管全生命周期。