Rust-线程:使用Sync和Send trait的可扩展并发
作者:互联网
Rust的并发模型中一个有趣的方面是:语言本身对并发知之甚少。我们之前讨论的几乎所有内容,都属于标准库,而不是语言本身的内容。由于不需要语言提供并发相关的基础设施,并发方案不受标准库或语言所限:我们可以编写自已的或使用别人编写的并发功能。
然而有两个并发概念是内嵌于语言中的:std::marker 中的 Sync 和 Send trait。
通过Send允许在线程间转移所有权
Send标记trait表明类型的所有权可以在线程间传递。几乎所有的Rust类型都是Send的,不过有一些例外,包括Rc<T>: 这是不能Send的,因为如果克隆了Rc<T>的值并尝试将克隆的所有权转移到另一个线程,这两个线程都可能同时更新引用计数。为此,Rc<T>被实现为用于单线程场景,这时不需要为拥有线程安全的引用计数而付出性能代价。
标签:trait,Sync,Send,并发,线程,Rc,Rust 来源: https://www.cnblogs.com/johnnyzhao/p/15376487.html