カスタムの異種リストとマップを作成しようとしています。マニフェストの使用に関する例はありますが、Scala 2.10では非推奨であり、TypeTags(またはClasstags)を使用する必要があります。マップの場合、(たとえば)タプルString->(TypeTag [_ <:Any]、Any)を使用して、AnyのTypeへのバインドを保持できるようです。
私の問題は、回復されたTypeTagと未定義のTから取得して、TypeTag.tpeのインスタンスを返すことができるようにする方法です-コード内のある時点で
//** How do I use saved typeTag to define T here?**
記述されているように、メソッドgetにはコンパイラエラーはありませんが、TはNothingに設定され、Some(Nothing)を返します。コメントアウトされた行を機能させたいと思い
case Some( x ) => // println( "Get 2*'pi'=" + x*2 )
ます。「値*はNothingのメンバーではありません」というメッセージが表示されます。もっとコンパクトに書くことができると思いますが、そうすることで、IDEにマウスオーバーして、ステップバイステップで進むことができます。関連する質問があります-Scala:TypeTagとは何ですか?どのように使用しますか? しかし、それは「ラストマイル」にはならないようです-Anyのタグを付け直します。
これを行う方法?
これが私がこれまでに持っているコードです:
import scala.reflect._
import scala.reflect.runtime.universe._
import collection.mutable.Map
object Test extends HMap {
def main( args: Array[ String ] ) {
var hmap = new HMap
hmap( "anInt" ) = 1
hmap( "pi" ) = 3.1416f
hmap( "c" ) = "hello"
// Test
val result = hmap.get( "pi" )
result match {
case Some( x ) =>
println( "Get 'pi'=" + x*2 )
case _ =>
}
}
}
class HMap {
private var coreMap =
Map.empty[ String, ( TypeTag[ _ <: Any ], Any ) ]
// Save the type tag with the value
def update[ T: TypeTag ]( key: String, value: T ) =
coreMap.put( key, ( typeTag[ T ], value ) )
override def toString = coreMap.toString
def get[ T: TypeTag ]( key: String ): Option[ T ] = {
val option = coreMap.get( key )
val result = option match {
case None => None
case Some( x ) => {
val typeTag = x._1; val value = x._2
println( "Matched Type = " +
typeTag.tpe + " Value=" + value )
// **** How do I use saved typeTag to define T here? ****
val v = value.asInstanceOf[ T ]
val s = Some( v )
println( "Returning " + s )
s
}
}
result
}
}