2

我一直在为这个烦人的问题苦苦挣扎一段时间,但没有找到一个优雅的解决方案。

假设我有这样一个类层次结构:

class StatWithBounds[A](val min: A, val max: A, val currentValue: A)
class StatBetween0And20(initialValue: Int) extends StatWithBounds[Int](0, 20, initialValue)
class PositiveStatOnly(initialValue: Int) extends StatWithBounds[Int](0, Integer.MAX_VALUE, initialValue)
class UncappedPercentage(initialValue: Int) extends StatWithBounds[Int](0, Integer.MAX_VALUE, initialValue)

initialValue 的复制/粘贴过于冗长。此外,如果我想做这样的事情:

class Strength(initialValue: Int) extends StatBetween0And20(initialValue)
class Intelligence(initialValue: Int) extends StatBetween0And20(initialValue)
class Piety(initialValue: Int) extends StatBetween0And20(initialValue)

多么糟糕的复制/粘贴(想象我还有 10 个子类)!

有没有一种优雅的方法来解决这个混乱的问题?

4

1 回答 1

5

如果您不需要原始类,则可以使用特征:

trait StatWithBounds[A] {
  def min: A
  def max: A
  def currentValue: A
}

trait StatBetween0And20 extends StatWithBounds[Int] {
  def min = 0
  def max = 20
}

class Strength(val currentValue: Int) extends StatBetween0And20
class Intelligence(val currentValue: Int) extends StatBetween0And20
...

或者,您可以根本不使用这么长的变量名!

class Stat[A](val min: A, val max: A, val current: A)
class Stat20(i: Int) extends Stat[Int](0, 20, i)
class Strength(i: Int) extends Stat20(i)
class Intelligence(i: Int) extends Stat20(i)
...

看看噪音少了多少?长变量名是样板文件的一种形式。有时为了清楚起见,您需要它,但通常不是将参数传递给构造函数。

于 2012-12-21T11:52:41.377 回答