- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在大多数具有参数/泛型类型的语言中,您可以编写一个(类型)表达式来表示“某物的集合”。例如。 Set<Integer>
在 Java 中。
类似地,在 OCaml 中,我们有类似列表的东西 int list
.
不过int set
好像没法说在 OCaml 中。 (或者也许我只是还没有找到/弄清楚如何)。
没有“通用集”类型。相反,有一个 Set
包含一个名为 Make
的“仿函数”的模块您将其传入另一个模块,其中包含“有序”类型的定义。
所以我们必须做类似的事情:
module IntSet = Set.Make(Int)
let numbers : IntSet.empty
因此我们声明了一个模块IntSet
其中包含对 int
的集合进行操作的函数.它还包含一个类型 IntSet.t
这基本上相当于 Set<Int>
在 Java 中。
这在某种程度上是有道理的。但有点烦人的是,这迫使我们为要在程序中使用的每种类型的 Set 选择显式名称,并在某个地方显式定义它(IntSet、StringSet、FloatSet 等)。
有没有办法避免这种情况?也许一些类似于 Java 的内联/匿名/简洁方式 Set<...>
构建 IntSet
本地模块而不给它一个名字?
我尝试过类似的方法,但它不起作用。
let numbers = Set.Make(Int).empty
(* ^^^^^^^^ unbound constructor Set.Make *)
奇怪的是,这种符号似乎在 .mli
中起作用。文件声明仅限类型:
val numbers : Set.Make(Int).t
这给了它应该成为可能的希望。
最佳答案
重要的一点是不可能只从一个类型构建一个集合(具有 ln(n)
查询复杂性)。集合由类型 和 对此类型的比较函数定义。例如,Java 的 TreeSet<T>
仅对实现比较器接口(interface)的类型 T 有效,或者如果构造函数被赋予比较器函数则有效。
OCaml 基于仿函数的集合使这种关系在类型级别变得明显可见。例如,我可以为 float
定义一个集合和温度作为 float (温度之间的物理正确比较)
module Float_set = Set.Make(Float)
module Temperature = struct
type t = float
let compare x y = match x > 0, y > 0 with
| true, false -> -1 (* negative temperatures are hotter than positive ones *)
| false, true -> 1
| false, false -> Stdlib.compare x y
| true, true -> Stdlib.compare y x
end
module Temperature_set = Set.Make(Temperature)
和类型 Temperature_set.t
和 Float_set.t
将是不同的和不兼容的,即使两个集合的元素都是 float 的。
关于module - 是否有一种简洁/内联的方式来创建 Set 值而不显式命名它们的类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72180298/
我正在用 C# 编写动态语言的解释器,并将原始函数实现为具有虚拟 Apply 方法的抽象类 Primitive,其中每个实际原始函数都是重写 Apply 的子类。 (另一种方法是只拥有类 Primit
我正在用 C# 编写动态语言的解释器,并将原始函数实现为具有虚拟 Apply 方法的抽象类 Primitive,其中每个实际原始函数都是重写 Apply 的子类。 (另一种方法是只拥有类 Primit
我是 Dapper 的新手我正在尝试了解它实际上是如何映射事物的。我有以下数据库结构: calendar | Id | Name | meeting_room | Id | Calendar_id
抱歉问题标题很糟糕。有没有办法在一行中做到这一点: Button button = (Button)Gridview.Cells[0].FindControl("controlname"); butt
在 Java 中在声明点和使用点声明列表/数组文字的tersest方法是什么? 作为次要问题,我更喜欢一种不会导致编译时警告或要求抑制警告的方法。 注意:就我个人而言,这是针对Java 8ish on
什么是现代、简洁、快速的方法来测试节点是否有任何与给定选择器匹配的子节点? “简洁”是指类似于 jQuery 或函数式风格,例如避免循环。我知道本地选择器越来越多地使用这种类型的东西,但没有跟上发展的
getFirstNotNullResult 执行函数列表,直到其中一个函数返回非空值。 如何更优雅/简洁地实现 getNotNullFirstResult? object A { def main
根据 stackoverflow 上某人的推荐,我使用了 jquery succint https://github.com/micjamking/Succinct截断我在 php 网站上的帖子。 它
我是一名优秀的程序员,十分优秀!