-
Go中“goroutine内存泄漏”本质是goroutine卡在select等阻塞操作而永不退出,并非堆内存未被GC回收。172 收藏 -
Go并发基于goroutine+channel的协作式系统,非多线程模拟;goroutine是运行时管理的轻量单元,初始栈2KB,由GMP调度,非OS线程;需限流防阻塞I/O失控;channel核心是协调时序而非传数据。235 收藏 -
Go无内置深拷贝,需手动递归或序列化实现;手动递归用reflect遍历重建值,注意处理指针、struct、slice、map、interface等类型及循环引用。126 收藏 -
直接用golang.org/x/time/rate。它是官方维护的生产级令牌桶实现,基于原子操作和单调时钟,支持rate.Limit和burst参数,避免自行实现的并发安全、时钟漂移等问题。118 收藏 -
GoRPC默认同步阻塞,性能瓶颈在于连接与序列化开销;优化核心是异步调用(goroutine+channel)和连接池复用,需用唯一ID、sync.Map缓存channel、context超时控制防泄漏。454 收藏 -
Go语言利用goroutine和channel实现高效并发,通过WebSocket协议构建聊天室,核心在于使用Hub模式管理客户端连接与消息广播,结合sync.Mutex保证并发安全,以非阻塞方式处理消息发送,确保高并发下服务稳定。264 收藏 -
time.Sub()计算时间差必须确保两时间点时区一致,否则结果为UTC偏移差而非钟表时间差;Duration支持纳秒级精确运算但不提供年月方法,因日历逻辑复杂;解析字符串需显式指定时区,推荐用ParseInLocation;判断相对日期应优先用AddDate而非Sub后换算。349 收藏 -
接口能否接收值取决于方法集匹配:值接收者时Person和Person均可;指针接收者时仅Person可赋值,Person{}因无法取地址而编译失败。103 收藏 -
根本原因是Go模块依赖解析默认锁定go.mod中精确版本,手动升级可能引入不兼容API变更;官方方案是通过/v2等主版本路径区分不兼容大版本,而非自动降级。182 收藏 -
本文详解Godep在多包单仓库项目中的正确使用方式,指出在子目录执行godepsave会导致本地包被错误vendoring的根本原因,并提供从项目根目录统一管理依赖的标准实践。376 收藏 -
etcd分布式锁不能直接用Put+Delete模拟,因裸Put无自动过期、裸Delete无法校验所有权;必须用Lease绑定TTL,并通过CAS(PrevKV+Txn)确保加锁和释放的原子性与安全性。112 收藏 -
errgroup.WithContext是并发错误处理的起点,需传入带cancel的context并在子任务中显式检查ctx.Err(),否则无法及时中断;Wait仅返回首个非nil错误,不汇总全部错误。336 收藏 -
gvm切不动版本主因是GOROOT或GOBIN被硬编码覆盖,需检查并删除相关export语句,确保gvm初始化脚本位于shell配置末尾;gomodtidy报错多因GO111MODULE/GOPROXY配置不当;GOPATH不隔离导致冲突应改用gowork或动态GOPATH;install卡住常因缺失C工具链或OpenSSL头文件。186 收藏 -
Go直连Ollama只需HTTP请求http://localhost:11434/api/chat;需配置OLLAMA_HOST=0.0.0.0:11434、确认模型loaded、非流式设Stream=false、流式需手动剥离data:前缀并逐块解码。407 收藏 -
Go语言中不能直接对map取地址,因为map本身是引用类型;声明*map[K]V虽合法但极少实用,仅在需替换整个map实例或统一管理生命周期时才需使用。333 收藏