mirror of
https://github.com/bevyengine/bevy
synced 2024-12-26 21:13:09 +00:00
32 lines
979 B
Rust
32 lines
979 B
Rust
|
use bevy_tasks::TaskPoolBuilder;
|
||
|
|
||
|
// This sample demonstrates a thread pool with one thread per logical core and only one task
|
||
|
// spinning. Other than the one thread, the system should remain idle, demonstrating good behavior
|
||
|
// for small workloads.
|
||
|
|
||
|
fn main() {
|
||
|
let pool = TaskPoolBuilder::new()
|
||
|
.thread_name("Idle Behavior ThreadPool".to_string())
|
||
|
.build();
|
||
|
|
||
|
pool.scope(|s| {
|
||
|
for i in 0..1 {
|
||
|
s.spawn(async move {
|
||
|
println!("Blocking for 10 seconds");
|
||
|
let now = std::time::Instant::now();
|
||
|
while std::time::Instant::now() - now < std::time::Duration::from_millis(10000) {
|
||
|
// spin, simulating work being done
|
||
|
}
|
||
|
|
||
|
println!(
|
||
|
"Thread {:?} index {} finished",
|
||
|
std::thread::current().id(),
|
||
|
i
|
||
|
);
|
||
|
})
|
||
|
}
|
||
|
});
|
||
|
|
||
|
println!("all tasks finished");
|
||
|
}
|