0

我有一些代码,其中有一组函数。每个函数可能有 1 或 2 个参数。在遍历这些函数时,我会检查元素的类型是 Function1 还是 Function2。问题是我开始收到类型擦除警告,因为我必须定义参数数据类型才能编译(例如 Function2[String,Int] - 请参阅下面的示例警告+)。

我了解 Java 在编译时会剥离参数类型信息,因此它无法与我定义的 Function2 模式匹配。问题是,我只想测试函数的类型是 Function1 还是 Function2,然后我就知道需要传递给函数的数据类型。我尝试将它们定义为 ex。Function2[Any,Any] 和 Function2[Object,Object],但这些都没有抑制警告。有没有办法对不同参数计数的函数进行模式匹配,而不要求它也检查参数类型?

[warn] /home/ubuntu/aa-2-0/src/main/scala/hw.scala:818: non-variable type argument Any in type Any => Any is unchecked since it is eliminated by erasure
[warn]                  else if(col_data.isInstanceOf[Function1[Any,Any]])  mapped_data+= col -> col_data.asInstanceOf[Function1[Any,String]].apply(page)
[warn]                                               ^
[warn] /home/ubuntu/aa-2-0/src/main/scala/hw.scala:819: non-variable type argument Any in type (Any, Any) => Any is unchecked since it is eliminated by erasure
[warn]                  else if(col_data.isInstanceOf[Function2[Any,Any,Any]]) mapped_data+= col -> col_data.asInstanceOf[Function2[Any,Any,String]].apply(result_row,page)

我知道有反射和标记类型等等,但这些看起来像丑陋且过于复杂的黑客来解决我相当微不足道的问题。相反,我打算将这些函数封装在 FunctionOne,FunctionTwo 案例类中,然后只测试它们,但想先看看是否有更优雅的解决方案可以学习。

4

1 回答 1

2

我不会制作不同函数类型的分类列表,这会给你带来这个问题。但如果必须,您可以使用通配符:

if(col_data.isInstanceOf[Function1[_,_]])

(您也可以使用加糖符号_ => _(_,_) => _

于 2013-11-05T20:42:32.623 回答