Jas*_*son 0 enumeration scala object
请考虑以下代码段,其中按字母顺序排列从1到9的所有数字:
object AlphabetizedDigit extends Enumeration {
type AlphabetizedDigit = Value
val one, two, three, four, five, six, seven, eight, nine = Value
}
println(for(i <- Range(0, AlphabetizedDigit.maxId)) yield (i, AlphabetizedDigit(i)))
Run Code Online (Sandbox Code Playgroud)
由于零索引,输出println将有点不直观:
jason@debian:~/code/atomicscala$ scala EnumIDRange.scala
Vector((0,one), (1,two), (2,three), (3,four), (4,five), (5,six), (6,seven), (7,eight), (8,nine))
Run Code Online (Sandbox Code Playgroud)
处理此问题的一种方法是更改AlphabetizedDigit成员的定义,如下所示:
val one = Value(1)
val two, three, four, five, six, seven, eight, nine = Value
Run Code Online (Sandbox Code Playgroud)
然后确保从而不是Range开始.然后输出是直观的:10
jason@debian:~/code/atomicscala$ scala EnumIDRange.scala
Vector((1,one), (2,two), (3,three), (4,four), (5,five), (6,six), (7,seven), (8,eight), (9,nine))
Run Code Online (Sandbox Code Playgroud)
但是,如果您只想切换枚举的起始索引,我真的不喜欢您需要将声明分成两行.因此,我尝试了以下,编译得很好:
val one, two, three, four, five, six, seven, eight, nine = Value(1)
Run Code Online (Sandbox Code Playgroud)
但是,在运行时,AssertionError由于使用了重复的ID ,我会被抛出.这对我来说很有意义,这不会起作用,但我很好奇为什么在运行时而不是编译时抛出此错误.
您可以使用Enumeration的第二个构造函数,例如:
object AlphabetizedDigit extends Enumeration(1) {
type AlphabetizedDigit = Value
val one, two, three, four, five, six, seven, eight, nine = Value
}
Run Code Online (Sandbox Code Playgroud)
表格文件:new Enumeration(initial: Int).
| 归档时间: |
|
| 查看次数: |
97 次 |
| 最近记录: |