我尝试编写一个应该使用周围范围变量的方法.问题是我无法访问定义变量的代码部分.像这样的东西:
object Example extends App {
val myvar = 1.0 // cannot change that code
def myMethod()(implicit value:Double) = {
print(value)
}
myMethod()
}
Run Code Online (Sandbox Code Playgroud)
这失败了,因为myMethod无法找到合适的隐含value.
value除了定义指向的新隐式变量之外,还有一种方法可以在定义之后将其"标记" 为隐式value吗?
背景:我们使用Spark-Notebook 自动创建SparkContext(命名sc).作为sc社区中此变量的一个众所周知的名称,我们不希望引入另一个变量名称.
如果你只是不想让它的实例SparkContext没有标记,sc你可以将它分配给一个隐式下划线变量,如下所示:
implicit val _: SparkContext = sc
Run Code Online (Sandbox Code Playgroud)
这将在您的函数使用范围内创建正确类型的隐式变量.
或者,您可以始终显式传递隐式变量,在上面的示例中,您可以执行此操作
myMethod()(myvar)
Run Code Online (Sandbox Code Playgroud)
这就是我要用的解决方案.
| 归档时间: |
|
| 查看次数: |
454 次 |
| 最近记录: |