问题描述
我知道 tokio 允许编写并发代码。但我不确定它是否并行运行。我的电脑有八核。所以理想情况下,我不会运行超过 8 个线程。如果我需要更多的并发性,我会在这些线程之上运行协程(使用 tokio)。
当然,除非 tokio 已经是多线程的。在这种情况下,一开始就创建这八个线程会适得其反。所以我想问的是,默认情况下 tokio 是多线程的,还是我应该自己实现?
解决方法
是的。 Tokio 是多线程的。您可以通过 tokio::main
宏自定义运行时创建的工作线程数。示例:
#[tokio::main(flavor = "multi_thread",worker_threads = 10)]
async fn main() {
// your code here
}