Map[Long, String]
キーの降順で繰り返し処理したい があります。これを行うために私が選んだ方法は次のとおりです。
var m: SortedMap[Long, String] = TreeMap.empty( (l: Long) => -l)
m ++= Map(2L -> "Hello", 1L -> "World", 3L -> "Chris")
println(m) //Map(3 -> Chris, 1 -> World, 2 -> Hello)
なぜこれがうまくいかなかったのか理解できず、ばかげた間違いを犯したとしか思えません。もちろん、次のように動作します。
var m: SortedMap[Long, String] = TreeMap.empty( (l: Long) => new Ordered[Long] {
def compare(a: Long) = -l.compare(a)
})
m ++= Map(2L -> "Hello", 1L -> "World", 3L -> "Chris")
println(m) //Map(3 -> Chris, 2 -> Hello, 1 -> World)