golang
已收录文章:14276篇
-
缓冲区优化在Golang网络编程中至关重要,它通过减少系统调用、降低内存分配和避免数据复制来提升高并发下的吞吐量与响应速度。核心策略包括使用bufio.Reader/Writer聚合I/O操作以减少syscall开销,利用sync.Pool复用[]byte减少GC压力,以及通过io.CopyBuffer自定义缓冲区提升复制效率。实践中需注意sync.Pool对象不保证存活、状态需手动管理、不适合长期存储或资源型对象,避免潜在资源泄漏。合理组合这些方法可显著优化网络应用性能。221 收藏
-
<p>Go语言支持函数返回多个值,适用于错误处理和数据解耦。定义时在括号内列出返回类型,如funcgetNameAndAge()(string,int),调用时用name,age:=getNameAndAge()接收,可使用下划线忽略无需的值,还能命名返回值以简化逻辑,如funcsplit(sumint)(x,yint){x=sum*4/9;y=sum-x;return},常用于返回结果与error,提升代码清晰度。</p>221 收藏
-
使用sync.RWMutex+map可实现带过期机制的线程安全缓存,适合需精细控制的场景;高频读、键集稳定的场景可用sync.Map提升性能;通过后台goroutine定期清理过期项,结合实际需求选择方案。221 收藏
-
命令模式结合队列可实现任务调度解耦,Golang通过接口封装命令、通道传递任务,协程异步执行,提升系统扩展性与可控性。221 收藏
-
引子 如今很多云原生系统、分布式系统,例如 Kubernetes,都是用 Go 语言写的,这是因为 Go 语言天然支持异步编程,而且静态语言能保证应用系统的稳定性。笔者的开源项目 Crawlab 作为爬虫管理220 收藏
-
GoLang之iface 和 eface 的区别是什么? iface 和 eface 都是 Go 中描述接口的底层结构体,区别在于 iface 描述的接口包含方法,而 eface 则是不包含任何方法的空接口:interface{}。 从源码层面看一下: ty220 收藏