tokio 的理解

tokio 基本上是 rust 异步编程中是最重要的库.
它融合了线程和协程的概念, 对外提供了 task 的概念.

首先, 它会启动和管理一个线程池, worker threads, 线程的数目基本上与 CPU 的核数相对应.

其次, rust 的语法 async await, 是会创建实现 Future 的状态机, 即通俗说的创建 future . 不同的 Runtime 系统来处理这些 future

再次, tokio 是一种 Runtime 实现, tokio 会将这些 future 包装成 task, 放入到 tokio 内部的调度器序列.

然后, tokio 的 worker 线程会轮询这些 task.

那么有个问题: 这些 task 是协程吗?

基本上也是协程的范畴, 但不是传统的协程, 与 go 的基于栈的协程机制不同, 这个是基于状态机的.

  • 每个 task 没有独立的栈
  • 不会抢占, 也是合作式调度, 只有在一个 task 主动调用 await 的时候, 才会让出执行权.
  • 上面这一点, 就满足协程单词中的的概念, 即协作/合作式调度.

或者说, async await 本身就是协程的概念, 而 tokio 只是一种具体的实现.

worker 的工作内容:

  • poll Tasks
  • 处理 IO 事件
  • 驱动异步执行
相关推荐
Mr -老鬼12 小时前
Rust适合干什么?为什么需要Rust?
开发语言·后端·rust
Mr -老鬼12 小时前
Rust与Go:从学习到实战的全方位对比
学习·golang·rust
superman超哥15 小时前
Context与任务上下文传递:Rust异步编程的信息高速公路
开发语言·rust·编程语言·context与任务上下文传递·rust异步编程
古城小栈16 小时前
Rust 已经自举,却仍需GNU与MSVC工具链的缘由
开发语言·rust
古城小栈1 天前
Rust 迭代器产出的引用层数——分水岭
开发语言·rust
peterfei1 天前
IfAI v0.2.8 技术深度解析:从"工具"到"平台"的架构演进
rust·ai编程
栈与堆1 天前
LeetCode-1-两数之和
java·数据结构·后端·python·算法·leetcode·rust
superman超哥1 天前
双端迭代器(DoubleEndedIterator):Rust双向遍历的优雅实现
开发语言·后端·rust·双端迭代器·rust双向遍历
福大大架构师每日一题1 天前
2026年1月TIOBE编程语言排行榜,Go语言排名第16,Rust语言排名13。C# 当选 2025 年度编程语言。
golang·rust·c#
superman超哥2 天前
精确大小迭代器(ExactSizeIterator):Rust性能优化的隐藏利器
开发语言·后端·rust·编程语言·rust性能优化·精确大小迭代器