Lua 数组排序 table.sort的注意事项

1. table中不能有nil

table.sort是排序函数,它要求要排序的目标table的必须是从1到n连续的,即中间不能有nil。

2. 重写的比较函数,两个值相等时不能return true

此外,当比较函数没有写的时候,table.sort默认按照lua里面的排序规则升序排序;

当额外写了比较函数时,相当于用你额外写的比较函数重载了lua中自带的“<”操作符。

这就有一个特别要注意的问题,当两个数相等的时候,比较函数一定要返回false!

如果两个值相等都,

排序函数返回true时则会报错 invalid order function for sorting

table.sort(tmpQueue, function(a, b)
        if (a == nil or b == nil) then
            return (a.endTime < b.endTime) --此处千万不能用小于等于
    end)