Lua | 面试题每日一练 (1)

💢欢迎来到张胤尘的技术站

💥技术如江河,汇聚众志成。代码似星辰,照亮行征程。开源精神长,传承永不忘。携手共前行,未来更辉煌💥

文章目录

Lua | 每日一练 (1)

题目

详细说明 lua 中表的索引机制,以及如何区分表的数组部分和哈希部分。此外,解释 lua 中表的索引从1开始的原因。

参考答案

lua 中,表是一种非常灵活的数据结构,既可以作为数组(数组部分)使用,也可以作为哈希表(哈希部分)使用。表的索引机制基于键值对,其中键可以是任意类型(除了 nil),值也可以是任意类型。

lua 复制代码
-- 创建一个表,包含数组部分和哈希部分
local myTable = {
    "apple",                -- 数组部分,索引为 1
    "banana",               -- 数组部分,索引为 2
    "cherry",               -- 数组部分,索引为 3
    fruit = "orange",       -- 哈希部分,键为字符串 "fruit"
    [4] = "date",           -- 数组部分,索引为 4(虽然不是连续的,但仍然是数组部分)
    [10] = "grape",         -- 哈希部分,索引为 10(非连续整数)
    [true] = "boolean_key", -- 哈希部分,键为布尔值
    [3.14] = "float_key"    -- 哈希部分,键为浮点数
}

-- 使用 ipairs 遍历数组部分
-- 1	apple
-- 2	banana
-- 3	cherry
-- 4	date
for index, value in ipairs(myTable) do
    print(index, value)
end

-- 使用 pairs 遍历整个表(包括数组部分和哈希部分)
-- 1	apple
-- 2	banana
-- 3	cherry
-- fruit	orange
-- 10	grape
-- 4	date
-- 3.14	float_key
-- true	boolean_key
for key, value in pairs(myTable) do
    print(key, value)
end

从上面的代码中可以看出,对于 [4] = "date" 来说作为数组部分进行存储,而对于 [10] = "grape" 当作哈希部分存储;实际上lua 在表的内部中会根据索引的连续性密度来动态决定哪些键值对存储在数组部分,哪些存储在哈希部分。

具体规则如下:

  • 数组部分的定义
    • 数组部分是指表中连续的整数索引 ,通常从 1 开始。
    • lua 会尝试将连续的整数索引优化为数组部分,因为数组部分的存储和访问效率更高。
  • 哈希部分的定义
    • 哈希部分用于存储非连续的整数索引非整数键(如字符串、浮点数、布尔值等)。
    • 哈希部分的存储和访问基于哈希表机制,时间复杂度通常为 O(1)
  • 动态区分机制
    • lua 的表在内部维护一个数组部分 和一个哈希部分
    • 当表的索引是连续的整数时,lua 会尽量将这些索引存储在数组部分。
    • 如果表中存在非连续的整数索引或非整数键,这些键值对会被存储在哈希部分。

根据以上规则也就可以解释执行打印的结果原因,另外也有一些在实际使用过程中的注意事项:

  • 数组部分的边界lua 会根据表的使用情况动态调整数组部分和哈希部分的边界。例如,如果数组部分的索引被删除,lua 可能会将其视为哈希部分。
  • # 运算符# 运算符只能获取数组部分的长度,不会考虑哈希部分的键值对。例如:
lua 复制代码
local myTable = {
    "apple",
    "banana",
    "cherry",
    fruit = "orange",
    [4] = "date",
    [10] = "grape",
    [true] = "boolean_key",
    [3.14] = "float_key"
}

print(#myTable) -- 4

最后对于 lua 表中索引从1开始,而不是类似于 c/c++golang 那样从0开始,经过在官方或者其他网站的查询结果,总结了这样设计的原因主要有:

  • 使用习惯 :在日常生活中,人们通常从 1 开始计数,例如"第一项"、"第二项"。从 1 开始的索引更符合人类的直觉。
  • 表达便捷 :从 1 开始的索引可以简化数学表达式。例如,访问第 n 个元素时,可以直接使用 array[n],而不需要像从 0 开始的索引那样使用 array[n-1]
  • 历史原因lua 的设计受到 Pascal 等早期语言的影响,这些语言的数组索引也是从 1 开始的。

Pascal 是一种过程式编程语言,由 Niklaus Wirth 于1968年设计并于1970年发布,并以法国数学家和哲学家 Blaise Pascal 的名字命名。

🌺🌺🌺撒花!

如果本文对你有帮助,就点关注或者留个👍

如果您有任何技术问题或者需要更多其他的内容,请随时向我提问。

相关推荐
郝学胜-神的一滴3 分钟前
深入探索 C++ 元组:从基础到高级应用
开发语言·c++·stl·软件工程
I'm a winner3 分钟前
第七章:AI进阶之------输入与输出函数(一)
开发语言·人工智能·python·深度学习·神经网络·microsoft·机器学习
木心操作11 分钟前
js生成excel表格进阶版
开发语言·javascript·ecmascript
听情歌落俗24 分钟前
MATLAB3-1变量-台大郭彦甫
开发语言·笔记·算法·matlab·矩阵
用户490558160812533 分钟前
lvs会话同步
后端
用户490558160812533 分钟前
linux内核网络协议栈报文的处理过程
后端
夜宵饽饽33 分钟前
上下文工程实践 - 工具管理(上篇)
javascript·后端
ERP老兵_冷溪虎山36 分钟前
Python/JS/Go/Java同步学习(第十三篇)四语言“字符串转码解码“对照表: 财务“小南“纸式转码术处理凭证乱码崩溃(附源码/截图/参数表/避坑指南)
java·后端·python
努力的小郑40 分钟前
MySQL索引(四):深入剖析索引失效的原因与优化方案
后端·mysql·性能优化
智商偏低44 分钟前
ASP.NET Core 中的简单授权
后端·asp.net