- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我刚刚开始学习Scala,我正在关注的许多教程都将main
方法的不同表示形式结合使用。除了熟悉的主要方法外,还使用了特质App
或Application
。
看来Application
已被弃用,不建议使用,但我找不到任何有关这些定义入口点的方法的详细说明。
因此,我想知道是否有人可以向我解释:
App
和Application
如何工作? Application
特性,而App
特性又有什么不同呢? App
启动程序?两种方法有什么区别? 最佳答案
Application
特征的问题实际上在其文档中进行了描述:
(1) Threaded code that references the object will block until static initialization is complete. However, because the entire execution of an object extending Application takes place during static initialization, concurrent code will always deadlock if it must synchronize with the enclosing object.
Application
特性,则基本上是在创建Java类:
class MyApplication implements Application {
static {
// All code goes in here
}
}
MyApplication
类上隐式同步运行上述类初始化器。这样,可以确保在初始化
MyApplication
的类之前不会创建任何实例。如果您从应用程序中产生一个再次需要访问
MyApplication
实例的线程,则您的应用程序将死锁,因为类初始化仅在整个程序执行后才完成。这意味着一个悖论,因为只要您的程序正在运行,就无法创建任何实例。
(2) As described above, there is no way to obtain the command-line arguments because all code in body of an object extending Application is run as part of the static initialization which occurs before Application's main method even begins execution.
args
方法上收到的
main
丢失了。
(3) Static initializers are run only once during program execution, and JVM authors usually assume their execution to be relatively short. Therefore, certain JVM configurations may become confused, or simply fail to optimize or JIT the code in the body of an object extending Application. This can lead to a significant performance degradation.
static
方法仅执行一次,因为它们无法手动调用。因此,它不会优化从类初始化程序运行的代码,但是,如果您正在使用
main
特性,则它是应用程序的
Application
方法代码。
App
特性通过扩展
DelayedInit
修复了所有问题。 Scala编译器明确知道此特征,因此初始化代码不是从类初始化程序运行,而是从其他方法运行。请注意特质唯一方法的for名称引用:
trait Helper extends DelayedInit {
def delayedInit(body: => Unit) = {
println("dummy text, printed before initialization of C")
body
}
}
DelayedInit
时,Scala编译器将其实现类或对象的所有初始化代码包装到for name函数中,然后将其传递给
delayedInit
方法。没有初始化代码直接执行。这样,您还可以在运行初始化程序之前运行代码,例如,这允许Scala将应用程序的运行时指标打印到控制台,该控制台包裹在程序的入口和导出周围。但是,由于存在
some caveats of this approach,因此不建议使用
DelayedInit
。您实际上应该仅依靠
App
特性来解决
Application
特性带来的问题。您不应该直接实现
DelayedInit
。
main
方法,只要在
object
中定义它即可。这主要是风格问题:
object HelloWorld {
def main(args: Array[String]) {
println("Hello, world!")
}
}
关于scala - 在斯卡拉;我应该使用App特性吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24437423/
我有一些 Scala 代码,它用两个不同版本的类型参数化函数做了一些漂亮的事情。我已经从我的应用程序中简化了很多,但最后我的代码充满了形式 w(f[Int],f[Double]) 的调用。哪里w()是
如果我在同一目录中有两个单独的未编译的 scala 文件: // hello.scala object hello { def world() = println("hello world") }
val schema = df.schema val x = df.flatMap(r => (0 until schema.length).map { idx => ((idx, r.g
环境: Play 2.3.0/Scala 2.11.1/IntelliJ 13.1 我使用 Typesafe Activator 1.2.1 用 Scala 2.11.1 创建一个新项目。项目创建好后
我只是想知道如何使用我自己的类扩展 Scala 控制台和“脚本”运行程序,以便我可以通过使用实际的 Scala 语言与其通信来实际使用我的代码?我应将 jar 放在哪里,以便无需临时配置即可从每个 S
我已经根据 README.md 文件安装了 ensime,但是,我在低级 ensime-server 缓冲区中出现以下错误: 信息: fatal error :scala.tools.nsc.Miss
我正在阅读《Scala 编程》一书。在书中,它说“一个函数文字被编译成一个类,当在运行时实例化时它是一个函数值”。并且它提到“函数值是对象,因此您可以根据需要将它们存储在变量中”。 所以我尝试检查函数
我有 hello world scala native 应用程序,想对此应用程序运行小型 scala 测试我使用通常的测试命令,但它抛出异常: NativeMain.scala object Nati
有few resources在网络上,在编写与代码模式匹配的 Scala 编译器插件方面很有指导意义,但这些对生成代码(构建符号树)没有帮助。我应该从哪里开始弄清楚如何做到这一点? (如果有比手动构建
我是 Scala 的新手。但是,我用 创建了一个中等大小的程序。斯卡拉 2.9.0 .现在我想使用一个仅适用于 的开源库斯卡拉 2.7.7 . 是吗可能 在我的 Scala 2.9.0 程序中使用这个
有没有办法在 Scala 2.11 中使用 scala-pickling? 我在 sonatype 存储库中尝试了唯一的 scala-pickling_2.11 工件,但它似乎不起作用。我收到消息:
这与命令行编译器选项无关。如何以编程方式获取代码内的 Scala 版本? 或者,Eclipse Scala 插件 v2 在哪里存储 scalac 的路径? 最佳答案 这无需访问 scala-compi
我正在阅读《Scala 编程》一书,并在第 6 章中的类 Rational 实现中遇到了一些问题。 这是我的 Rational 类的初始版本(基于本书) class Rational(numerato
我是 Scala 新手,我正在尝试开发一个使用自定义库的小项目。我在库内创建了一个mysql连接池。这是我的库的build.sbt organization := "com.learn" name :
我正在尝试运行一些 Scala 代码,只是暂时打印出“Hello”,但我希望在 SBT 项目中编译 Scala 代码之前运行 Scala 代码。我发现在 build.sbt 中有以下工作。 compi
Here链接到 maven Scala 插件使用。但没有提到它使用的究竟是什么 Scala 版本。我创建了具有以下配置的 Maven Scala 项目: org.scala-tools
我对 Scala 还很陌生,请多多包涵。我有一堆包裹在一个大数组中的 future 。 future 已经完成了查看几 TB 数据的辛勤工作,在我的应用程序结束时,我想总结上述 future 的所有结
我有一个 scala 宏,它依赖于通过包含其位置的静态字符串指定的任意 xml 文件。 def myMacro(path: String) = macro myMacroImpl def myMacr
这是我的功能: def sumOfSquaresOfOdd(in: Seq[Int]): Int = { in.filter(_%2==1).map(_*_).reduce(_+_) } 为什么我
这个问题在这里已经有了答案: Calculating the difference between two Java date instances (45 个答案) 关闭 5 年前。 所以我有一个这
我是一名优秀的程序员,十分优秀!