有个猜用户喜欢的功能,用户可以通过点击换一组,来刷新推荐的内容。 先通过数据库查询,得到前1000条数据,然后随机去除4条。 程序写完之后,发现运行的很慢,每次刷新,都要等
有个猜用户喜欢的功能,用户可以通过点击换一组,来刷新推荐的内容。
先通过数据库查询,得到前1000条数据,然后随机去除4条。
程序写完之后,发现运行的很慢,每次刷新,都要等很久才出来。
代码如下:
$arr = range(1, 100000); $start = time(); for($i = 0; $i < 100; $i ++){ $key = mt_rand(0, 99999 - $i); $result[] = $arr[$key]; unset($arr[$key]); sort($arr); } $end = time(); echo $end - $start;
上面的写法,用unset之后,必须进行排序。
unset只会删除键值,而key会保留。
经过改进之后的写法如下:
$arr = range(1, 100000); $start = time(); for($i = 0; $i < 100; $i ++){ $key = mt_rand(0, 99999 - $i); $result[] = array_splice($arr, $key, 1); } $end = time(); echo $end - $start;
效率提高了3-4倍。