- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试在 Scala 中使用泛型,但在某些情况下它对我不起作用。
我定义了一个类:
trait Generic[T <: Product] extends Serializable {
def start(ssc: StreamingContext, conf: Conf) = {
val dstream = createDirectStream(...)
val rdd = dstream.map(x => avroToObject(x.value()))
execute(rdd)
}
def execute(dstreamAvro: DStream[T]): Unit
def avroToObject(bytes: Array[Byte]): T
}
后来,我在具体的类中实现了avroToObject方法。当我尝试编译代码时出现错误。
Error:(36, 30) No ClassTag available for T
val rddAvro = dstream.map(x => avroToObject(x.value()))
Error:(36, 30) not enough arguments for method map: (implicit evidence$2: scala.reflect.ClassTag[T])org.apache.spark.streaming.dstream.DStream[T].
Unspecified value parameter evidence$2.
val rddAvro = dstream.map(x => avroToObject(x.value()))
这是怎么回事?我该如何解决?
如果我通过以下方式更改类的声明:
abstract class Generic[T <: Product](implicit c: ClassTag[T]) extends Serializable {..
它有效,但我不明白为什么,以及为什么它需要隐式。
最佳答案
What is it happening? How could I fix it?
正在发生的事情是,执行链中的一种方法需要存在 ClassTag[T]
的实例。虽然我们这里没有实现,但我假设这是 KafkaUtils.createDirectStream
方法,它在运行时需要 T
类型的信息。
这个有效:
abstract class Generic[T <: Product](implicit c: ClassTag[T])
因为现在当您调用 createDirectStream
时隐含在范围内。也就是说,编译器是在编译时为你填充相关类标签的编译器,现在 createDirectStream
有相关的隐含范围可以使用。
关于scala - 与 Scala 通用。没有可用于 T 的 ClassTag,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49588195/
我正在使用 Gunicorn 为 Django 应用程序提供服务,它工作正常,直到我将其超时时间从 30 秒更改为 900000 秒,我不得不这样做,因为我有一个用例需要上传和处理一个巨大的文件(过程
我有一个带有非常基本的管道的Jenkinsfile,它可以旋转docker容器: pipeline { agent { dockerfile { args '-u root' } } stag
在学习 MEAN 堆栈的过程中,我遇到了一个问题。每当我尝试使用 Passport 验证方法时,它都不会返回任何响应。我总是收到“localhost没有发送任何数据。ERR_EMPTY_RESPONS
在当今的大多数企业堆栈中,数据库是我们存储所有秘密的地方。它是安全屋,是待命室,也是用于存储可能非常私密或极具价值的物品的集散地。对于依赖它的数据库管理员、程序员和DevOps团队来说,保护它免受所
是否可以创建像图片上那样的边框?只需使用 css 边框属性。最终结果将是没 Angular 盒子。我不想添加额外的 html 元素。我只想为每个 li 元素添加 css 边框信息。 假设这是一个 ul
我是一名优秀的程序员,十分优秀!