RS.CLIPPY.LARGE_FUTURES
Large future may lead to unexpected stack overflows
This checker is a Clippy lint created by The Rust Project Contributors. The documentation shown here is a copy of the original documentation for: large_futures. Copyright ©2025 The Rust Team. All rights reserved.
What it does
It checks for the size of a Future created by async fn or async {}.
Why is this bad?
Due to the current unideal implementation of Coroutine,
large size of a Future may cause stack overflows.
Example
async fn large_future(_x: [u8; 16 * 1024]) {}
pub async fn trigger() {
large_future([0u8; 16 * 1024]).await;
}
Box::pin the big future instead.
async fn large_future(_x: [u8; 16 * 1024]) {}
pub async fn trigger() {
Box::pin(large_future([0u8; 16 * 1024])).await;
}
Configuration
-
future-size-threshold: The maximum byte size aFuturecan have, before it triggers theclippy::large_futureslint(default:
16384)