【问题标题】:No ClassTag Available (Scala)没有可用的 ClassTag (Scala)
【发布时间】:2015-09-28 17:47:29
【问题描述】:

我在 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
    }
}

我正在尝试运行此代码并遇到异常

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]
             ^

【问题讨论】:

    标签: scala apache-spark apache-kafka spark-streaming


    【解决方案1】:

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

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

    【讨论】:

    • 谢谢它的工作..如果你能解释什么是问题,那就太好了......
    • 问题在于Util.fun1 需要在调用范围内为ClassTag[K]ClassTag[M]ClassTag[KD]ClassTag[MD] 类型提供隐式值。但是,由于具体类型 K, M, KDMD 是未知的,编译器无法生成它们,并且必须由调用者在 ClassTagIssue 的范围内传递,因此在 build 方法的范围内传递。这实际上是通过将上下文边界添加到ClassTagIssue 的通用参数来完成的。每当您创建 ClassTagIssue 实例时,您还必须为这些类型提供 ClassTag 实例。
    猜你喜欢
    • 1970-01-01
    • 2016-04-26
    • 1970-01-01
    • 1970-01-01
    • 2022-10-16
    • 1970-01-01
    • 1970-01-01
    • 2022-01-26
    • 2018-05-02
    相关资源
    最近更新 更多