在Lua中实现表格以便于访问以供日后使用。

我正在尝试制作一个表格,其中包含三个部分,每个部分的长度都很大。第一个是名称,第二个是 EID,第三个是 SID。我想能够像这样获取信息:name[1]给我名称列表中的第一个名称,对于其他两个也是这样。我遇到的问题是如何做到这一点,因为似乎每个人都有自己的方式,它们都非常不同。现在这就是我拥有的东西。

info = {
       {name = "btest",  EID = "19867", SID = "664"},
       {name = "btest1", EID = "19867", SID = "664"},
       {name = "btest2", EID = "19867", SID = "664"},
       {name = "btest3", EID = "19867", SID = "664"},
     }

从理论上讲,我能否只说info.name[1]?还是说我该如何安排表格,以便我可以单独访问每个部分?

点赞
用户3080396
用户3080396

有两种主要的存储数据的方式:

水平分割(面向对象)

将每一行数据存储在表中。所有表必须具有相同的字段。

优点:每个表都包含相关数据,因此更容易传递它(例如,f(info[5]))。 缺点:需要为每个元素创建一个表,增加了一些开销。

这看起来与您的示例完全相同:

info = {
    {name = "btest",  EID = "19867", SID = "664"},
    -- 等等...
}

print(info[2].name) -- 访问第二个名称

垂直分割(面向数组)

将每个属性存储在表中。所有表必须具有相同的长度。

优点:总体上需要更少的表,并且 稍微 更加时间和空间效率高(Lua VM 使用实际数组)。 缺点:需要两个对象引用一行:表和索引。更难插入/删除。

您的示例将如下所示:

info = {
    names = { "btest", "btest1", "btest2", "btest3", },
    EID   = { "19867", "19867",  "19867",  "19867",  },
    SID   = { "664",   "664",    "664",    "664",    },
}

print(info.names[2]) -- 访问第二个名称

那我应该选择哪一个?

除非您真的 需要 性能,否则您应该选择水平分割。在使用整行时更为常见,并且在使用结构时会给您更多的自由度。如果您决定全面采用面向对象,那么将数据以水平方式存储将容易得多。


附录

“水平”和“垂直”这些名称来自关系数据库的表表示。

  | names | EID | SID |         | names |
--+-------+-----+-----+         +-------+
1 |       |     |     |         |       |       --+-------+-----+-----+
2 |       |     |     |         |       |       2 |       |     |     |
3 |       |     |     |         |       |       --+-------+-----+-----+
2014-06-10 16:08:03
用户869951
用户869951

你的 info 表是一个数组,因此你可以使用 info[N] 访问项目,其中 N 是从 1 到表中项目数的任何数字。info 表的每个字段本身都是一个表。info 的第二项是 info[2],因此该项的 name 字段是 info[2].name

2014-06-11 05:29:24