刚看了项目里面的的一个小代码,发现table.sort还有这样使用的功能,第一次碰到,学习了在此记录下,说明了自己还是需要多看代码啊,才能提高自己。
以前都知道table.sort()的第二个参数是可以传一个比较函数的,以用来比较嵌套table的某个key值排序。 简单来说需求就是这样的,举个例子test = {{k1=v1,k2=v2},{k1=v1,k2=v2},{k1=v1,k2=v2},{k1=v1,k2=v2}},
代码语言:javascript复制要对此test排序的要求是,按照k1值从大到小排序,若是k1值一样的情况下,则按照k2的值从小到大排序,以此类推。。。多个字段一样的先后排序顺序。
table.sort(living_user_list,function(v1,v2)
if v1.tpvp_score > v2.tpvp_score then
return true
end
if v1.tpvp_score < v2.tpvp_score then
return false
end
-- v1.tpvp_score == v2.tpvp_score
if v1.last_update_tpvp_score_ts < v2.last_update_tpvp_score_ts then
return true
end
if v1.last_update_tpvp_score_ts > v2.last_update_tpvp_score_ts then
return false
end
--最后还是一样,那么就根据uid来判断
if v1.user_id > v2.user_id then
return true
end
return false
end)
这样主要就为了得到排序后table的key ,也就我们需要的rank号。
代码语言:javascript复制local rank = 0
local score = 0
for k,v in pairs(living_user_list) do
if v.user_id == user_id then
rank = k
score = v.tpvp_score
end
end
return score,rank