oop - Scala mixin 真的比多重 C++ 继承更好吗?

标签 oop scala traits

就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the help center寻求指导。




8年前关闭。




人们说 C++ 继承是邪恶的,所以 Java 用接口(interface)“修复”了这个问题。

但是 Scala 引入了 trait s,它们是……部分实现的接口(interface)?这不是带回了多重继承吗?

这是否意味着 Scala 的人认为多重继承很好?或者他们有一些我没有注意到的关键差异?

最佳答案

多重继承最糟糕的部分是菱形继承,其中子类有两个或多个路径到链上某处的同一父级。如果实现沿两条路径不同(即从原始实现覆盖),这会产生歧义。在 C++ 中,解决方案特别难看:您嵌入了两个不兼容的父类,并且必须指定何时调用您想要的实现。这很令人困惑,在每个调用站点都会产生额外的工作(或者,更有可能的是,迫使您显式地覆盖并声明您想要的;这种手动工作很乏味,并且会引入错误的机会),并且可能导致对象大于他们应该是。

Scala 通过将多重继承限制在特征上,解决了一些但不是全部的问题。因为traits没有构造函数,最终类可以线性化继承树,也就是说,即使在返回公共(public)超父的路径上的两个父代名义上都是父代,一个是“正确”的一个,即一个最后列出。如果您可以拥有(完全通用的)构造函数,此方案将留下损坏的半初始化类,但事实上,您不必两次嵌入该类,并且在使用站点您可以忽略多少继承(如果有的话)发生了。然而,当你将许多特征叠加在一起时,以及如果你从两个 B 继承时,它并没有更容易推理会发生什么和 C ,你不能选择拿一些B的实现和 C 的一些实现的。

所以更好的是它解决了对 C++ 模型的一些最严重的批评。是否足够好是品味问题;很多人甚至喜欢 C++ 多重继承的味道,足以使用它。

关于oop - Scala mixin 真的比多重 C++ 继承更好吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16873365/

相关文章:

javascript - javascript类中的自动增量值

scala - 为什么在 Option[T] 的 HList 上映射不起作用?

scala - 当定义闭包时,Scala 如何维护变量的值?

php trait 使用另一个 trait

generics - 如何迭代实现 Index 和 IntoIterator 的通用集合的索引?

javascript - 为什么在 javascript 中使用基于类的 OOP 样式继承?

java - 《Effective Java》第 16 条(第 2 版)- 转发类仅用于允许重用吗?

c# - 构造函数和继承

scala - 带有文件的喷雾客户端上传表单

rust - Rust 可以调用抽象函数吗?