加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Scala – 使用伴随对象作为函数接受块的简写参数

发布时间:2020-12-16 18:24:09 所属栏目:安全 来源:网络整理
导读:我有一组模型对象和一组包装器对象,以提供额外的功能. 我希望能够简洁地将模型对象的集合转换为包装器对象,使用相同的简写,允许您编写List(“x”,“y”,“z”).foreach(println),如下所示: class Modelclass ModelWrapper(val m: Model)object ModelWrapper
我有一组模型对象和一组包装器对象,以提供额外的功能.

我希望能够简洁地将模型对象的集合转换为包装器对象,使用相同的简写,允许您编写List(“x”,“y”,“z”).foreach(println),如下所示:

class Model
class ModelWrapper(val m: Model)
object ModelWrapper { def apply(model: Model) = new ModelWrapper(model) }

val m1 = new Model; val m2 = new Model; val m3 = new Model

List(m1,m2,m3).map(ModelWrapper)

因此,作为参数传递的ModelWrapper将转换为ModelWrapper(_),这是对伴随对象的调用.

但是,当我尝试这个时,我得到一个类型不匹配错误,如下所示:

<console>:14: error: type mismatch;
 found   : ModelWrapper.type (with underlying type object ModelWrapper)
 required: Model => ?
                  List(m1,m3).map(ModelWrapper)

但是,如果我将ModelWrapper作为案例类,并删除伴随对象,它就可以工作.我不想把它作为一个案例类,因为它添加的行为不适合案例类工作的整体方式.例如,具有相同模型类作为参数的两个包装类不一定相等.

我想知道的是,在这种情况下,案例类和伴随对象之间有什么区别?我可以在不使用案例类的情况下得到我想要的东西吗?

解决方法

您的伴侣对象必须是一个函数:

object ModelWrapper extends Function1[Model,ModelWrapper] { def apply(model: Model) = new ModelWrapper(model) }

或者你可能更喜欢这个缩写:

object ModelWrapper extends (Model => ModelWrapper) { def apply(model: Model) = new ModelWrapper(model) }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读