尝试用ListSet类中的具体类型扩展一个ListSetConcreteType,然后每次需要一个ListSetConcreteType实例时,我都会传递一个桩实例。
class Pile extends ListSet[Card]{
def this(cards: ListSet[Card]){
this()
this ++ cards
}
def draw(amount: Int = 1): (Pile, Pile) = this.splitAt(amount)
}在“绘制”方法中,编译器指责类型的表达式(ListSetCard,ListSetCard)不符合预期的类型(桩、桩),但简单地说:
type Pile = ListSet[Card]在堆体内解决问题。我真的应该使用类型别名和extend关键字吗?(我非常希望创建一个新的类,而不仅仅是给它提供别名)
ps:我的构造师看起来像疯了吗?这是我唯一能弄清楚的办法
发布于 2014-07-17 19:30:04
问题是splitAt返回ListSet[Card],虽然Pile扩展了ListSet[Card],但它不是一堆。
避免此问题的一种方法是将结果从splitAt转换为Pile。
def draw(amount: Int = 1): (Pile, Pile) = {
val (a,b) = this.splitAt(amount)
(new Pile(a), new Pile(b))
}的另一个想法.
您只希望返回Piles,以便使draw方法对结果可用。您可以在这里使用隐式类。现在,ListSet[Card]的所有实例都有了绘图方法。
implicit class Pile(cards: ListSet[Card]) {
def draw(amount: Int = 1) = cards.splitAt(amount)
}很小的例子。
type Card = Int
val pile = ListSet(1,2,3,4,5)
val (drawn, remaining) = pile.draw()
val (nextDrawn, nextRemaining) = remaining.draw(2) https://stackoverflow.com/questions/24811454
复制相似问题