这篇文章主要讲解了“scala的内部类怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“scala的内部类怎么使用”吧!
在Scala中,一个类可以作为另一个类的成员。 在一些类似 Java 的语言中,内部类是外部类的成员,而 Scala 正好相反,内部类是绑定到外部对象的。 假设我们希望编译器在编译时阻止我们混淆节点 nodes 与图形 graph 的关系,路径依赖类型提供了一种解决方案。
为了说明差异,我们简单描述了一个图形数据类型的实现:
class Graph { class Node { var connectedNodes: List[Node] = Nil def connectTo(node: Node) { if (!connectedNodes.exists(node.equals)) { connectedNodes = node :: connectedNodes } } } var nodes: List[Node] = Nil def newNode: Node = { val res = new Node nodes = res :: nodes res }}
该程序将图表示为节点列表 (List[Node]
)。 每个节点都有一个用来存储与其相连的其他节点的列表 (connectedNodes
)。 类 Node
是一个 路径依赖类型,因为它嵌套在类 Graph
中。 因此,connectedNodes
中存储的所有节点必须使用同一个 Graph
的实例对象的 newNode
方法来创建。
val graph2: Graph = new Graphval node1: graph2.Node = graph2.newNodeval node2: graph2.Node = graph2.newNodeval node3: graph2.Node = graph2.newNodenode1.connectTo(node2)node3.connectTo(node1)
为清楚起见,我们已经明确地将 node1
,node2
,和 node3
的类型声明为graph2.Node
,但编译器其实可以自动推断出它。 这是因为当我们通过调用 graph2.newNode
来调用 new Node
时,该方法产生特定于实例 graph2
的 Node
类型的实例对象。
如果我们现在有两个图,Scala 的类型系统不允许我们将一个图形中定义的节点与另一个图的节点混合,因为另一个图形的节点具有不同的类型。下例是一个非法的程序:
val graph2: Graph = new Graphval node1: graph2.Node = graph2.newNodeval node2: graph2.Node = graph2.newNodenode1.connectTo(node2) val graph3: Graph = new Graphval node3: graph3.Node = graph3.newNodenode1.connectTo(node3)
类型 graph2.Node
与类型 graph3.Node
完全不同。在 Java 中,上一个示例程序中的最后一行是正确的。对于两个图的节点,Java 将分配相同的类型 Graph.Node
; 即 Node
以类 Graph
为前缀。在Scala中也可以表示出这种类型,它写成了 Graph#Node
。如果我们希望能够连接不同图形的节点,我们必须通过以下方式更改图类的初始实现的定义:
class Graph { class Node { var connectedNodes: List[Graph#Node] = Nil def connectTo(node: Graph#Node) { if (!connectedNodes.exists(node.equals)) { connectedNodes = node :: connectedNodes } } } var nodes: List[Node] = Nil def newNode: Node = { val res = new Node nodes = res :: nodes res }}
感谢各位的阅读,以上就是“scala的内部类怎么使用”的内容了,经过本文的学习后,相信大家对scala的内部类怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。