Lua5.2.3源码阅读(3)-Table(ipairs,pairs)

本文详细介绍了Lua5.2.3中表的长度计算,通过源码分析luaH_getn函数揭示了#运算符在面对含有nil值的连续序列时可能产生的问题。此外,还探讨了table的遍历机制,luaH_next函数如何处理数组和哈希部分的元素。同时,文章提到了rehash过程及其在luaH_newkey中的触发条件。最后,对比了ipairs与pairs在遍历table时的区别,强调了在遍历过程中插入元素可能导致的不确定性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

“#”lua表长度计算

    local a = {};
    a[1] = 10;
    a[2] = 20;
    a[3] = 30;
    a[4] = 40;
    --a[6] = 60;
    a[7] = 70;

    print(#a);  -->4

    local a = {};
    a[1] = 10;
    a[2] = 20;
    a[3] = 30;
    a[4] = 40;
    a[6] = 60;
    a[7] = 70;

    print(#a);  -->7

这里就比较奇怪了,得到的不是table的长度。Lua文档中说,如果是一个连续的序列,那么才可以用#计算table的长度,如果中间有nil值,计算将会有问题。那就到源码中找找答案。#计算长度调用的是lua_rawlen函数,该函数如下。

LUA_API size_t lua_rawlen (lua_State *L, int idx) {
  StkId o = index2addr(L, idx);
  switch (ttypenv(o)) {
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值