是否有 Erlang 数组 "with a defined representation"?

Are there Erlang arrays "with a defined representation"?

上下文:

异构节点上的 Erlang 程序 运行,检索和存储数据 来自 Mnesia 数据库。这些数据库条目将长期使用 时间(例如,跨多个 Erlang 版本发布)保持为 Erlang 对象(即无序列化)。在存储的信息中,有 目前数组有两种用途:

  1. 大型(最多 16384 个元素)数组。快速访问元素 使用其索引是选择此类集合的基础。 一旦创建了数组,就永远不会修改元素。

  2. 小型(最多 64 个元素)数组。访问主要使用索引完成,但也有一些迭代 (foldl/foldr)。元素的读取和替换都经常进行。集合的大小保持不变。

问题:

Erlang's documentation on arrays 声明“表示不是 记录在案,如有更改,恕不另行通知。”显然,数组不应该在我的上下文中使用:包含数组的数据库条目可能是 根据执行程序的节点进行不同的解释,并且 对数组的实现方式进行未经宣布的更改会使它们无法使用。

我注意到 Erlang 具有 "ordsets"/"orddict" 功能来解决类似的问题 "sets"/"dict" 的问题,因此我正在寻找 "array" 等价物。你知道吗?如果 none 存在,我的策略可能是使用列表的列表来替换我的大数组,并使用 orddict(以索引作为键)替换较小的数组。有更好的解决方案吗?

数组是嵌套的元组和整数的元组,每个元组的大小固定为 10,代表一段单元格。如果某个段当前未使用,则整数 (10) 用作占位符。这没有抽象是我想壁橱 equivalent.You 确实可以从 otp 复制数组模块并添加到您自己的应用程序,因此它将是一个稳定的表示。

至于你应该在没有数组的情况下使用什么取决于数据以及你将如何处理它。如果数组中的数据是固定的,那么一个元组就会生成,因为它具有 reads/lookups 的恒定访问时间。否则列表听起来像是赢家,无论是列表列表、元组列表等。但是,再一次,这是在黑暗中拍摄的,因为我不知道您的数据或您如何使用它。

在此处查看实现:https://github.com/erlang/otp/blob/master/lib/stdlib/src/array.erl

另请参阅 Robert Virding 关于数组实现的回答:Arrays implementation in erlang

Fred Hebert 在 A Short Visit to Common Data Structures

中对数组的评价

显示数组结构的示例:

1> A1 = array:new(30).
{array,30,0,undefined,100}
2> A2 = array:set(0, true, A1).
{array,30,0,undefined,
       {{true,undefined,undefined,undefined,undefined,undefined,
              undefined,undefined,undefined,undefined},
        10,10,10,10,10,10,10,10,10,10}}
3> A3 = array:set(19, true, A2).
{array,30,0,undefined,
       {{true,undefined,undefined,undefined,undefined,undefined,
              undefined,undefined,undefined,undefined},
        {undefined,undefined,undefined,undefined,undefined,
                   undefined,undefined,undefined,undefined,true},
        10,10,10,10,10,10,10,10,10}}
4>