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