没有ClassTag可用(Scala)

Rah*_*kla 1 scala apache-kafka apache-spark spark-streaming

在Scala中我发生了一些奇怪的事情.我正在尝试使用第三方库

org.apache.spark.streaming.kafka.KafkaUtils.createDirectStream

并获得No ClassTag异常.我模拟下面的场景,因为人们可以将Util视为第三方库.为什么会这样?

object Util {
    def fun1[K: ClassTag, M: ClassTag, KD: ClassTag, MD: ClassTag]: Unit = {
        println("In function version 2")
    }
}

class ClassTagIssue[K, M, KD, MD] {
    def build: Unit = {
        Util.fun1[K, M, KD, MD]
    }
}

object ClassTagIssue {
    def main(args: Array[String]) {
        new ClassTagIssue[String, String, String, String]().build
    }
}
Run Code Online (Sandbox Code Playgroud)

我正在尝试运行此代码并获得以下异常

Error:(23, 14) No ClassTag available for K
    Util.fun1[K, M, KD, MD]
             ^
Error:(23, 14) not enough arguments for method fun1: (implicit evidence$1: scala.reflect.ClassTag[K], implicit evidence$2: scala.reflect.ClassTag[M], implicit evidence$3: scala.reflect.ClassTag[KD], implicit evidence$4: scala.reflect.ClassTag[MD])Unit.
Unspecified value parameters evidence$1, evidence$2, evidence$3, ...
    Util.fun1[K, M, KD, MD]
             ^
Run Code Online (Sandbox Code Playgroud)

Til*_*ann 5

您必须将该ClassTag类添加为绑定到泛型类型的上下文ClassTagIssue.这样,您告诉编译器,在创建实例时ClassTags,类型K, M, KDMD将可用ClassTagIssue.

class ClassTagIssue[K: ClassTag, M: ClassTag, KD: ClassTag, MD: ClassTag] {
  def build: Unit = {
    Util.fun1[K, M, KD, MD]
  }
}
Run Code Online (Sandbox Code Playgroud)