我正在尝试制作类似于数组的东西。
我需要能够“释放”一个索引(将其值设置为未定义),但我不想丢失索引。每当将新项目放入数组时,都应重新使用“已发布”的索引。
我希望能够做类似的事情:
example = new MyArray();
a = example.leaseIndex(); // returns 0
example[a] = "example value";
b = example.leaseIndex(); // returns 1
example[b] = "another value";
example.releaseIndex(0);
c = example.leaseIndex(); // returns 0
example[c] = "yet another value";
在我的示例中,leaseIndex 找到一个可用的索引,或者如果没有可用的索引,则将新项目推送到数组中并返回该项目的索引。
我想这样做,这样数组就不会随着时间的推移而不必要地变大。我无法删除“已发布”项目,因为数组中的每个项目都包含对同一数组中另一个项目的引用。
我在主函数和数组之外的函数和数组上取得了一些成功,以跟踪可用索引并分配和释放它们,但理想情况下,我希望该功能成为主数组的一部分。
我是否必须将我的函数添加到数组(或其原型)中,还是有其他方法?因为并非我的所有阵列都需要此功能。
希望这是有道理的:/
更新
我正在尝试存储布线机布局,它本质上是一个网络图(点和关于点如何连接的信息)。
图为织机示例。它有 3 个连接器;红色 (0) 有 2 条线,黄色 (1) 有 3 条线,绿色 (2) 有 2 条线。红色连接器上的一条线是拼接的(允许多条线连接到一条线,蓝色方块)
这就是织布机的存放方式。
loom = {
points = [
{ self: 0, list: [ 2 ] },
{ self: 1, list: [ 7 ] },
{ self: 2, list: [ 0 ] },
{ self: 3, list: [ 7 ] },
{ self: 4, list: [ 6 ] },
{ self: 5, list: [ 7 ] },
{ self: 6, list: [ 4 ] },
{ self: 7, owner: 1, list: [ 1, 3, 5 ] }
],
connectors = [
[ 0, 1 ],
[ 2, 3, 4 ],
[ 5, 6 ]
]
}
连接器数组中的元素包含点数组中点的索引。每个点对象内的列表数组包含其目的地的索引,这些也是点。
我试图制作函数来帮助更轻松地管理索引,只是想知道是否有办法扩展数组,或者制作包含该功能的类似东西。使用静态函数就可以了,这也是我一直在使用的。我只是想看看我是否可以扩展数组,或者使用类似的东西,所以我不需要使用静态函数。