码迷,mamicode.com
首页 > 编程语言 > 详细

数组元素个数计算

时间:2020-01-30 21:23:43      阅读:106      评论:0      收藏:0      [点我收藏+]

标签:str   条件   lock   产生   作者   包括   tab   结束   https   

数组元素一定是从1开始的,顺序递增且不包含元素nil。只有这种情况才能正确的计算个数

数组与HASH并存,数组索引从1开始顺序递增,且值不能未Nil

 

local a1 = { 1, 2, 3 }

local a2 = { [1]=1,  [3]=2,  [5]=3,  [7]=4 }

local a3 = { [2]=3, [10]=2, [20]=2 }

local a4 = { 2, name=‘yuanbl‘, 3, age=25, 5, 9 }

local a5 = { name=‘yuanbl‘, age=25, sex=‘男‘}

local a6 = { 2, name=‘yuanbl‘, 3, age=25, 5, 9, hello=nil, 10 }

计算(# 或 table.getn())结果如下:

3

1

2

4

0

5

它是怎么做到的?

分析: table.getn(t) 和 #t 一样都是计算数组元素但不包括hash键值,并且数组元素一定是从1开始的,顺序递增且不包含元素nil。只有这种情况才能正确的计算个数,可知a1正确;再来分析a2,查找1成立,接着查找2,没有找到,结束查找,返回结果为1;a3不满足条件产生呵呵的结果;a4、a5、a6同理可分析。



作者:Uzero
链接:https://www.jianshu.com/p/e9f6d85b57b9
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

数组元素个数计算

标签:str   条件   lock   产生   作者   包括   tab   结束   https   

原文地址:https://www.cnblogs.com/justart/p/12243702.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!