3

我在调用老式哈希表时遇到了意外的麻烦。这里发生了什么?

Welcome to Scala version 2.8.0.final (Java HotSpot(TM) Client VM, Java 1.6.0_21).
Type in expressions to have them evaluated.
Type :help for more information.

scala> import com.ibm.mq._                 
import com.ibm.mq._

scala> MQEnvironment.properties                                                    
res1: java.util.Hashtable[_, _] = {}

scala> res1.put("transport", "MQSeries")
<console>:10: error: type mismatch;
 found   : java.lang.String("transport")
 required: ?0 where type ?0
       res1.put("transport", "MQSeries")
            ^

PS,问题仍然存在,但我有一个讨厌的解决方法:

scala> new java.util.Hashtable[String, String]
res10: java.util.Hashtable[String,String] = {}

scala> res10.put("transport", "MQSeries")      
res11: String = null

scala> MQEnvironment.properties = res10

scala> MQEnvironment.properties        
res13: java.util.Hashtable[_, _] = {transport=MQSeries}
4

1 回答 1

4

properties接口似乎是早于 Java 泛型的那些老式 API 之一。中的那些下划线java.util.HashTable[_, _]是存在类型的简写,其中第一个(键类型)对应于?0出现在诊断中。这些旧的 Java“原始”类型是 Scala 的 Java 互操作性中一个不幸的、可见的接缝,尽管它通常只出现在非常旧的 API 中。

于 2010-08-26T23:31:40.320 回答