- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何向 Haskell 专家解释 Scala 的类型系统?
哪些例子展示了 Scala 的优势?
如何向高级 Scala 从业者解释 Haskell 的类型系统?
在 Haskell 中可以完成哪些 Scala 无法完成的工作?
最佳答案
Scala 致 Haskell 程序员:
Scala 是一种严格且不纯的语言,具有一流的模块。数据类型被声明为具有细微差别的“类”或“特征”,模块或“对象”是这些类型的值。 Scala 支持采用通用量化类型参数的类型构造函数。对象/类/特征的成员由值、可变变量和函数(称为“方法”,模块作为名为 this
的变量隐式传递给它)组成。模块可能有类型成员,也可以带参数。类型成员是存在量化的,类型参数可以是更高级的。因为类型可以是一等值的成员,Scala 提供了一种称为 path-dependent types 的依赖类型。 .
一等函数也是模块。函数是具有名为 apply
的方法的模块.方法不是一流的,但提供了一种语法来将方法包装在一流的函数中。不幸的是,一个模块需要预先设置它的所有类型参数,因此部分应用的一流函数不允许被普遍量化。更一般地说,Scala 完全缺乏对高于 1 的等级类型的直接机制,但是可以利用在更高级类型上参数化的模块来模拟等级 n 类型。
Scala 允许您声明任何给定类型的隐式值,而不是具有全局作用域的类型类。这包括提供隐式转换和类型扩展的函数类型。除了隐式转换之外,类型扩展由“扩展”机制提供,它允许您声明模块之间的子类型/父类(super class)型关系。这种机制可用于模拟代数数据类型,其中父类(super class)型可以被视为数据声明左侧的类型,其子类型可以被视为右侧的值构造函数。 Scala 使用具有一流模式的虚拟化模式匹配器具有广泛的模式匹配功能。
Scala 支持子类型,这在很大程度上限制了类型推断。但随着时间的推移,类型推断得到了改进。支持更高级类型的推断。然而,Scala 缺乏任何有意义的种类系统,因此没有种类推断和种类统一。如果引入了一个类型变量,它的种类是 *
除非另有说明。某些类型,如 Any
(所有类型的父类(super class)型)和 Nothing
(每种类型的子类型)在技术上属于每种类型,尽管它们不能应用于类型参数。
Haskell 给 Scala 程序员:
Haskell 是一种纯函数式语言。这意味着函数根本不允许有任何副作用。例如,Haskell 程序不会像这样打印到屏幕上,而是一个返回 IO[_]
值的函数。描述 IO 子系统要执行的一系列操作的数据类型。
Scala 在默认情况下是严格的,并为非严格函数参数提供“按名称”注释,而 Haskell 在默认情况下使用“按需要”语义是惰性的,并为严格参数提供注释。
Haskell 中的类型推断比 Scala 中的更完整,具有完整的推断。这意味着几乎不需要类型注释。
GHC 编译器的最新扩展允许高级类型系统功能,这些功能在 Scala 中没有等价物,例如 rank-n 类型、类型系列和种类多态性。
在 Haskell 中,模块是类型和函数的集合,但模块不是一流的实体。隐式是由类型类提供的,但是一旦声明它们就是全局范围的,并且它们不能像在 Scala 中那样显式传递。通过用 newtype
包装来解析给定类型的类型类的多个实例。消除歧义,而在 Scala 中,这可以通过确定范围或显式传递实例来解决。
由于 Haskell 不是“面向对象的”,因此没有方法/函数二分法。每个函数都是一流的,默认情况下每个函数都是柯里化的(没有 Function1、Function2 等)。
Haskell 没有子类型机制,但是类型类可以有子类关系。
关于scala - Scala 和 Haskell 类型系统的区别和相似之处是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1815503/
我有一些 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 年前。 所以我有一个这
我是一名优秀的程序员,十分优秀!