- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
当从 C# 世界迁移到 F#(最惯用的可能)思维模式时,我发现了这个有趣的差异。
在 C# 的 OOP&mutable 世界中,默认集合集合似乎是 HashSet ,默认情况下似乎没有排序(因为它接受的比较器只是为了相等);而如果你想要一个排序的,你将不得不使用 SortedSet .
但是在 F# 的世界中,基本的 set
已经排序,因为它需要用于实现相等和比较的元素类型。这有什么具体原因吗?为什么不在这种语言的主要集合中使用无序集?
作为旁注,我想知道是否有可能有一个不允许重复的集合,但在将某些元素作为重复项丢弃时优先于某些元素。示例:一条记录 { Name: string; Flag: Option<unit> }
这样在插入 { Name = "foo"; Flag = None }
时及以后 { Name = "foo"; Flag = Some() }
它最终只包含后一个元素(因为存在 Flag)。
最佳答案
F# Set
恰好是排序的,但它更多的是由于选择底层数据结构而产生的实现细节,通常不应依赖。
F# 集和映射基于 AVL 树的一个变体,该结构恰好保持了存储在树中的元素已排序的不变性。它需要比较约束的原因是因为在此树结构中的查找依赖于元素之间的直接比较来选择遍历的子树。
然而,这些结构的卖点在于它们可用于以低廉的价格实现相当高效、不可变的映射和集合版本,而这正是 F# 在更广泛的 .NET 平台不提供任何服务时所需要的替代方案。
请注意,在这种情况下,这不是唯一可行的选择,Clojure 或 Scala 等 JVM 函数式语言选择了不同的数据结构作为其映射的基础 - 哈希数组映射 trie - 这也是不可变和持久的,可以说更实现起来很复杂,可以说对于更大的集合大小更有效,但碰巧存储元素是无序的。与AVL树不同,树的遍历是基于哈希的,所以不需要比较约束。
因此,如果您已经知道您的首要任务是不变性,那么排序集实际上比未排序集更容易实现。
关于c# - 为什么 F#'s default set collection is sorted while C#' 不是?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57393557/
自从我开始工作(约 6 年)以来,我一直是 .NET 的一员。最近在做一个使用Django的项目,需要并行学习Python。很多时候我碰到的 Python 代码看起来很简单,但我就是看不懂。这是其中之
谁能解释一下 JLS §8.4.8.4 中提到的“严格的default-abstract 和default-default 冲突规则” . 它们是否在 JLS 中定义?我似乎找不到他们的定义。 最佳答
我在我的启动图像通用项目中添加了“Default.png,Default-568h@2x.png,Default@2x.png”这三个文件,我有三个不同的图像,分辨率与苹果中提到的完全相同文档,适用于
我试图在删除 AWS RDS MySQL 数据库后删除默认的数据库参数组,但出现以下错误 Failed to delete default.mysql8.0: Default DBParameterG
我想使用 firebase 云函数发送通知,所以我尝试使用 firebase.messaging().getToken() 获取 token ,但我不断收到错误消息: TypeError: fireb
无法通过 Instagram 登录我的应用。我正在使用 react-native instagram 包,但我面临这个问题,因为 _react3.default.creteRef() 不是一个函数。引
从 Rust 1.6 开始,当前特征 Default定义为, pub trait Default { fn default() -> Self; } 为什么不是这个 pub trait Def
在我的第一次代码审查(不久前)中,我被告知在所有 switch 语句中包含默认子句是一种很好的做法。我最近想起了这个建议,但不记得其理由是什么。现在对我来说听起来很奇怪。 始终包含默认语句是否有合理的
这个错误很奇怪。在 firebase 中 react native 有什么问题我已经通过 npm install 安装了 firebase这是我的代码 import React, {Component
对于以下 3 种编译情况: gcc -o helloc hello.c (1) g++ -o hellocpp hello.cpp
我有一个 switch 语句。它几乎可以正常工作,但是它不仅显示一个案例,还显示选定的案例,然后显示默认案例。这是我的代码: var people = { names: ["Sam", "Tim"
这个问题在这里已经有了答案: Default keyword in Swift parameter (1 个回答) 关闭 6 年前。 我试图理解前置条件函数并遇到了“= default”。快速谷歌和
禁止!配置的服务帐户无权访问。服务帐户可能已被撤销。用户“system:serviceaccount:default:default”无法获取命名空间“mycomp-services-process”
我一直在我的 React 中广泛使用命名导出和默认导出,我遇到了这 2 个相似的语法。 从'./Button'导出默认值; export { default } from './Button'; 有人
我很困惑什么时候使用 .prototype 来扩展一个对象,什么时候不使用它。像下面的部分代码,为什么不在FacebookApi.defaults中使用.prototype,难道.prototype只
这个问题在这里已经有了答案: What is the difference between "var=${var:-word}" and "var=${var:=word}"? (4 个答案) 关闭
我想创建一个数据类基类,其中子类中的所有字段都自动可选且默认为无(如果未提供默认值)。 下面的代码……几乎可以满足我的要求,但又不完全是。它出错的方式就像我从未编写过 __init_subclass_
所以我有三个 Typescript 文件: 配置/env/development.ts import { Config } from '../config'; class DevConfig {
我在一个名为 Activity 的表中添加了一个名为 Ordinal 的新列。问题是我给了它一个 UNIQUE 约束,将它设置为允许 NULL(尽管我最终不会想要这个。我只需要将它设置为那个以使脚本更
嗨,我是 struts2 的新手,在我的项目中,我在注册页面使用 json-default 扩展,并使用validation.xml 文件验证它,在同一个项目中,我在登录页面使用 struts-def
我是一名优秀的程序员,十分优秀!