为了看出两者的区别,首先定义一个table: a={ "Hello", "World";a= 1,b= 2,z= 3,x= 10,y= 20; "Good", "Bye"} 使用ipairs对其进行遍历: for i, v in ipairs(a) do print(v) end 输出的结果是: Hello World Good Bye 可见
为了看出两者的区别,首先定义一个table:
a={"Hello","World";a=1,b=2,z=3,x=10,y=20;"Good","Bye"}
使用ipairs对其进行遍历:
- for i, v in ipairs(a) do
- print(v)
- end
输出的结果是:
Hello
World
Good
Bye
可见ipairs并不会输出table中存储的键值对,会跳过键值对,然后按顺序输出table中的值。
再使用pairs对其进行遍历:
- for i, v in pairs(a) do
- print(v)
- end
输出的结果是:
Hello
World
Good
Bye
1
10
2
20
3
可见pairs会输出table中的值和键值对,并且在输出的过程中先按顺序输出值,再乱序输出键值对。
这是因为table在存储值的时候是按照顺序的,但是在存储键值对的时候是按照键的哈希值存储的,并不会按照键的字母顺序或是数字顺序存储。
对于a来说,如果执行print(a[3]),输出的结果也会是Good。也就是说table并不会给键值对一个索引值。
也就是说ipairs只是按照索引值顺序,打印出了table中有索引值的数据,没有索引值的不管。
而pairs是先按照索引值打印,打印完成后再按照键值对的键的哈希值打印它的值。