golang
已收录文章:13890篇
-
select语句用于多路channel通信,每个case必须是channel操作,多个就绪时随机执行一个,避免饥饿问题。345 收藏
-
Golang通过sync.Pool对象重用、strings.Builder减少字符串拼接、预分配切片和map、自定义内存分配器、优化堆分配及逃逸分析等方法减少内存碎片,结合runtime监控和pprof分析,辅以操作系统大页内存、容器化隔离和定期重启等手段,可有效提升内存使用效率和程序性能。407 收藏
-
闭包能捕获外部作用域变量,但在循环中所有闭包共享同一变量实例,导致意外结果,需通过副本传递避免陷阱。437 收藏
-
Mutex解决数据竞态,确保共享资源的独占访问;WaitGroup用于等待一组协程完成,二者协同实现并发控制。158 收藏
-
使用net/http服务静态文件需配合http.FileServer和http.StripPrefix,开发时可直接用Go服务,生产环境建议交由Nginx或CDN;自Go1.16起可通过embed包将静态文件编译进二进制,实现一键部署;需防范路径遍历风险,避免敏感文件暴露。458 收藏
-
答案:Go中结构体值拷贝创建独立副本,适用于小型结构体和需数据隔离的场景,而指针传递仅复制地址,适合大型结构体和需修改原始数据的场景;值拷贝在小结构体上性能良好,但大结构体拷贝开销大,指针虽高效但需防范nil指针和并发竞争;最佳实践包括根据修改需求选择传值或传指针、方法接收者保持一致性、小结构体优先值类型、大结构体优先指针,并注意并发安全与初始化。109 收藏