先來看看下列案列:
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 }
計(jì)算(# 或 table.getn())結(jié)果如下:
3
1
2
4
0
5
它是怎么做到的?
分析: table.getn(t) 和 #t 一樣都是計(jì)算數(shù)組元素但不包括hash鍵值,并且數(shù)組元素一定是從1開始的,順序遞增且不包含元素nil。只有這種情況才能正確的計(jì)算個(gè)數(shù),可知a1正確;再來分析a2,查找1成立,接著查找2,沒有找到,結(jié)束查找,返回結(jié)果為1;a3不滿足條件產(chǎn)生呵呵的結(jié)果;a4、a5、a6同理可分析。
正確計(jì)算table元素個(gè)數(shù)
function isTable ( value )
? ? ? if type( value ) ~= "table" then
? ? ? ? ? ? ?value = {}
? ? ? ?end
? ? ? return ?value
end
function countNums ( t )
? ? ? local count = 0
? ? ? local t = isTable ( t )
? ? ? for k, v in pairs( t ) do
? ? ? ? ? ?count = count + 1
? ? ? end
? ? ? return ?count
end
ngx.say( isTable( a1 ) ) ? -- 3
ngx.say( isTable( a2 ) ) ? -- 4
ngx.say( isTable( a3 ) ) ? -- 3
ngx.say( isTable( a4 ) ) ? -- 6
ngx.say( isTable( a5 ) ) ? -- 3
ngx.say( isTable( a6 ) ) ? -- 7