【Rust日报】2023-09-12 Bevy 诞生三周年

2025-04-26阅读 0热度 0
rust git ai c++ red

【rust日报】2023-09-12 bevy 诞生三周年

使用 FuturesUnordered 处理多个 Future

在本文中,我们将探讨一个功能强大且高效的类型 futures::stream::FuturesUnordered,它能够同时处理多个异步任务,并以非阻塞的方式轮询多个任务,然后处理任务完成时获取的结果。

代码语言:javascript代码运行次数:0运行复制```javascriptuse futures::stream::FuturesUnordered;use futures::StreamExt;use std::pin::Pin;use std::future::Future;

[tokio::main]

async fn main() {// 创建一个 FuturesUnordered 结构体,所有的 Future 类型相同:Box>。let mut tasks = FuturesUnordered::>>>::new();// 使用 Box::pin 创建一个固定位置的、堆分配的 Future 版本。// 这确保了 Future 一旦开始执行,其内存位置不会改变。tasks.push(Box::pin(task_one()));tasks.push(Box::pin(task_two()));tasks.push(Box::pin(task_three()));while let Some(result) = tasks.next().await {println!("{}", result);}}

ReadMore: https://betterprogramming.pub/futuresunordered-an-efficient-way-to-manage-multiple-futures-in-rust-a24520abc3f6<p>QuickDiv 基于libdivide 的快速除法和取模</p><p>QuickDiv 是一个Rust包,基于libdivide C/C++库,允许您通过相同的除数加速重复的除法和取模运算。在大多数硬件上,整数除法操作的执行时间比乘法和加法等操作要长。因此,编译器通常通过将除以常数的操作替换为更快速的移位、乘法和加法序列来进行优化。本软件包允许您应用类似的算法来优化在运行时才能确定的值的除法操作。</p><p>代码语言:javascript代码运行次数:0<svg fill="none" height="16" viewbox="0 0 16 16" width="16" xmlns="<a href="https://www.php.cn/link/c9041cfd2a40932691855abd98fd219a">http://www.w3.org/2000/svg"><path</a> d="M6.66666 10.9999L10.6667 7.99992L6.66666 4.99992V10.9999ZM7.99999 1.33325C4.31999 1.33325 1.33333 4.31992 1.33333 7.99992C1.33333 11.6799 4.31999 14.6666 7.99999 14.6666C11.68 14.6666 14.6667 11.6799 14.6667 7.99992C14.6667 4.31992 11.68 1.33325 7.99999 1.33325ZM7.99999 13.3333C5.05999 13.3333 2.66666 10.9399 2.66666 7.99992C2.66666 5.05992 5.05999 2.66659 7.99999 2.66659C10.94 2.66659 13.3333 5.05992 13.3333 7.99992C13.3333 10.9399 10.94 13.3333 7.99999 13.3333Z" fill="currentcolor"></path></svg>运行<svg fill="none" height="16" viewbox="0 0 16 16" width="16" xmlns="<a href="https://www.php.cn/link/c9041cfd2a40932691855abd98fd219a">http://www.w3.org/2000/svg"><path</a> clip-rule="evenodd" d="M4.5 15.5V3.5H14.5V15.5H4.5ZM12.5 5.5H6.5V13.5H12.5V5.5ZM9.5 2.5H3.5V12.5H1.5V0.5H11.5V2.5H9.5Z" fill="currentcolor" fill-rule="evenodd"></path></svg>复制```javascriptuse quickdiv::DivisorU64;</p><p>fn is_quadratic_residue(q: u64, modulus: u64) -> bool {// 初始化一个除数比单个未优化的除法更昂贵,要获得好处,您必须多次使用相同的除数进行除法。let modulus = DivisorU64::new(modulus);// 通过使用 ::get() 可以恢复原始值。for x in (0..modulus.get()) {// 除数可以作为 / 和 % 运算符的第二个操作数使用。if (x * x) % modulus == q {return true;}}false}</p><p>assert!(is_quadratic_residue(152, 169));assert!(!is_quadratic_residue(51, 111));
登录后复制
免责声明

本网站新闻资讯均来自公开渠道,力求准确但不保证绝对无误,内容观点仅代表作者本人,与本站无关。若涉及侵权,请联系我们处理。本站保留对声明的修改权,最终解释权归本站所有。

相关阅读

更多
欢迎回来 登录或注册后,可保存提示词和历史记录
登录后可同步收藏、历史记录和常用模板
注册即表示同意服务条款与隐私政策