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