IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:goroutine

共 2 篇相关文章

IT 累计浏览 1,880

实现 go 的 goroutine 本地存储又一种方式

这篇讲的是Go语言中goroutine本地存储的一种新颖实现方案。 作者指出,Go本身没有提供便捷的goroutine本地存储,虽然可以通过`context`传递数据,但这要求在调用链上处处传递,侵入性较强。他发现Go标准库中用于性能剖析的`pprof`包里,隐藏着一个可以携带数据的`label`机制。 基于此,作者设计了一个巧妙的方案:利用其中一个label,通过一些底层技巧将一个`map`结构“塞”进去,从而在单个goroutine中携带所需的本地数据。同时,为了与标准库中基于`context`操作label的逻辑兼容,还做了相应的处理,防止数据被意外覆盖。 通过这种方式,作者将对原有pprof功能的干扰降到了最低。为此,他编写并开源了一个简洁的库:`github.com/xiezhenye/gls`,为需要goroutine本地状态的场景提供了一个侵入性较低的新选择。

IT 累计浏览 2,950

lua cothread

这篇讲的是Lua语言中的协程(coroutine)机制。作者从实际开发中遇到的并发处理挑战出发,详细拆解了Lua协程的实现原理和核心优势。Lua协程采用非对称设计,基于独立栈空间管理状态,切换时仅需保存少量上下文,因此比操作系统线程更轻量级,资源开销极小。 文章将Lua协程与Go的goroutine、Python的asyncio等模型进行了对比:goroutine依赖运行时自动调度,适合高吞吐量场景;而Lua协程需要通过显式的yield和resume调用来切换,提供了更精细的控制流,适合I/O密集型或需要精确协调的任务。作者强调,Lua协程在游戏服务器、网络代理等应用中表现突出,能够高效处理数万个并发连接,其巧妙之处在于用最小成本实现了协作式多任务,但这也要求开发者主动管理调度逻辑,避免阻塞。 通过源码层面的分析,文章指出Lua协程的栈式结构和状态保存机制是其高效的关键。最终结论是,Lua协程是解决特定并发问题的优雅工具,尤其适合对性能和控制有较高要求的嵌入式或实时系统环境。