了解Kotlin中的物化和通配符如何工作

如果问题的题目不是很重要,我很抱歉,但是我还没有找到更好的方法来描述这个问题。

我正在为Hadoop编写一些Kotlin扩展方法,昨天我列出了一个我不明白的奇怪错误。 我写了几个这样的扩展方法:

inline fun <reified T : InputFormat<*, *>, reified K : Mapper<*, *, *, *>> Job.addMultipleInputPath(path: Path) { MultipleInputs.addInputPath(this, path, T::class.java, K::class.java) } inline fun <reified T : OutputFormat<*, *>, reified Key : Any, reified Value : Any> Job.addMultipleNamedOutput(namedOutput: String) { MultipleOutputs.addNamedOutput(this, namedOutput, T::class.java, Key::class.java, Value::class.java) } inline fun <reified T : Mapper<*, *, KeyClass, ValueClass>, reified KeyClass : Any, reified ValueClass : Any> Job.setMapper() { this.setMapperClass<T>() this.mapOutput<KeyClass, ValueClass>() } 

如果我尝试在我的Driver类中调用它们,(1)和(3)工作但(2)给我一个编译错误:

 with(Job.getInstance()) { // works addMultipleInputPath<TextInputFormat, SensorsMapperType2>(secInput) // 2 type arguments expected for class TextOutputFormat<K: Any!, V: Any!> : FileOutputFormat<K!, V!> // defined in org.apache.hadoop.mapreduce.lib.output addMultipleNamedOutput<TextOutputFormat, Text, SensorData>(HIGH_TEMP) // works setMapper<NGramMapper, Text, IntWritable>() } 

如果我使用<TextOutputFormat<Any, Any>>来改正呼叫<TextOutputFormat<Any, Any>>一切正常,但我不明白为什么会发生这种情况。 有没有什么我错过了如何物化和泛型在Kotlin工作?

这是关于原始类型,kotlin不允许的。

这种格式的作品:

 addMultipleNamedOutput<TextOutputFormat<Text, SensorData>, Text, SensorData>(HIGH_TEMP) //(1) 

这两个不是:

 addMultipleNamedOutput<TextOutputFormat, Text, SensorData>(HIGH_TEMP) //(2) 

所以现在事情变得清晰了。 TextOutputFormat是非法的,因为Kotlin不允许原始类型。 你必须指定(2)中缺少的类型参数。 添加它们将导致格式(1)。

这看起来有点冗长,但目前没有解决方法(至少恕我直言)。