-
Go中HTTP错误处理应优先用http.Error,它自动设状态码和Content-Type;自定义JSON错误需手动WriteHeader和Header.Set;Redirect不可替代错误响应;中间件中http.Error后必须return防双写。160 收藏 -
字符串与数字转换可用strconv包实现,如Atoi、Itoa、ParseInt、FormatInt等函数,需注意错误处理和类型范围。221 收藏 -
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 收藏