Ruby 并发与测试基础
1. Ruby 中的 Ractor
在 Ruby 里,Ractor 是实现并发的重要方式,下面介绍其相关特性:
- 可共享对象
- 对于实例变量都可共享的对象实例,Ruby 提供了 Ractor.make_sharable(obj) 方法,它会遍历对象的所有属性并将其冻结,从而使任意对象变得可共享。若传入 copy: true 关键字参数,会复制该对象并返回副本。
- 可共享对象在传递给 Ractor 时会被共享,即传递的是对象的引用,发送方和接收方都能访问该对象。不可共享对象会被复制,除非在 Ractor.send 或 Ractor.yield 中传入 move: true 。若移动了不可共享对象,它将可供新的 Ractor 使用,而发送它的 Ractor 则无法再访问,尝试访问会抛出异常。
- 条件接收
- 可使用 Ractor.receive_if 方法让 Ractor 对接收的内容进行筛选,该方法接受一个块作为参数。当其他 Ractor 向等待 receive_if 的 Ractor 发送对象时,接收的 Ractor 会对发送的对象调用该块。若块返回真值, receive_if 会像普通的 receive 方法一样返回该对象;若返回假值,Ractor 会继续等待。失败的对象会留在队列头部,当 Ra
超级会员免费看
订阅专栏 解锁全文
871

被折叠的 条评论
为什么被折叠?



