Rust 多线程开发:scoped thread

在 Rust 中,"scoped thread" 指的是一种特殊的线程,它的生命周期被限制在创建它的作用域内。这与标准的 std::thread::spawn 函数创建的线程不同,后者创建的线程可以在其父作用域结束后继续运行。Scoped thread 的主要优势在于它们允许安全地访问父作用域中的数据,而无需将数据的所有权移动到线程中。

普通线程(std::thread::spawn

  1. 生命周期分离 :使用 std::thread::spawn 创建的线程与创建它的作用域(通常是主线程)生命周期分离。这意味着创建的线程可以在其父作用域结束后继续运行。
  2. 数据共享限制 :由于生命周期的分离,向这些线程传递引用变得复杂。通常需要使用 move 关键字,将数据的所有权转移到线程内部。这可能需要使用原子操作或线程安全的共享内存(如通过 Arc 实现)。
  3. 手动管理 :创建者需要手动管理这些线程,比如通过 join 明确等待线程完成,否则线程可能会变成孤儿线程。

Scoped Thread

  1. 生命周期绑定:Scoped thread 的一个关键特性是它们的生命周期与创建它们的作用域绑定。这意味着,scoped thread 必须在创建它的作用域结束之前完成执行。
  2. 安全的数据共享:由于生命周期绑定,可以更安全地向 scoped thread 传递对父作用域数据的引用。编译器能保证这些引用在 scoped thread 的整个生命周期内都是有效的,这简化了共享数据的过程。
  3. 自动管理 :由于它们与创建作用域的生命周期绑定,scoped thread 在作用域结束时会自动等待它们的完成(通常是通过隐式的 join)。这意味着它们不会变成孤儿线程,并且确保了在作用域结束前,所有线程相关的活动都已经完成。

例子

rust 复制代码
#[test] //这是一个属性,用于标记接下来的函数是一个测试函数。
pub fn test_scope_thread() { 

    let mut v = vec![1, 2, 3]; 
    let mut x = 1; 
    
    //创建了一个 scoped thread 的作用域。在这个作用域内,你可以启动与该作用域生命周期相关联的线程。
    thread::scope(|s| { 
        //尝试在一个新线程中修改 `x` 的值。
        s.spawn(|| { x = 3; }); 
    }); 
    
    //创建了另一个 scoped thread 的作用域。
    thread::scope(|s| { 
        //在一个新线程中向向量 `v` 添加一个元素
        s.spawn(|| { 
            v.push(1);
        });
    }); 
    
    assert_eq!(v, [1, 2, 3, 4]);
    assert_eq!(x, 3);
}

这段代码尝试展示了使用 thread::scope 来创建 scoped threads,并在这些线程中访问和修改外部变量。 过

Scoped thread 是 Rust 中处理并发时一种非常有用的模式,特别是当需要安全地在多个线程之间共享数据时。虽然它们在使用上有一定的限制,但通过提供额外的安全保障,它们在许多场景下都是非常有价值的。from Pomelo_刘金,转载请注明原文链接。感谢!

相关推荐
愿天垂怜22 分钟前
【C++】C++11引入的新特性(1)
java·c语言·数据结构·c++·算法·rust·哈希算法
mit6.82427 分钟前
[Redis#4] string | 常用命令 | + mysql use:cache | session
数据库·redis·后端·缓存
捂月1 小时前
Spring Boot 核心逻辑与工作原理详解
java·spring boot·后端
Nightselfhurt2 小时前
RPC学习
java·spring boot·后端·spring·rpc
Estar.Lee8 小时前
查手机号归属地免费API接口教程
android·网络·后端·网络协议·tcp/ip·oneapi
2401_8576100310 小时前
SpringBoot社团管理:安全与维护
spring boot·后端·安全
凌冰_11 小时前
IDEA2023 SpringBoot整合MyBatis(三)
spring boot·后端·mybatis
码农飞飞11 小时前
深入理解Rust的模式匹配
开发语言·后端·rust·模式匹配·解构·结构体和枚举
一个小坑货11 小时前
Rust 的简介
开发语言·后端·rust
AskHarries11 小时前
如何将Spring Cloud Task发布Data Flow上执行?
java·后端·spring cloud