19、Ruby 并发与测试基础

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值