>백엔드 개발 >PHP 튜토리얼 >PHP는 대규모 배열에서 임의의 작은 배열을 빠르게 가져옵니다.

PHP는 대규모 배열에서 임의의 작은 배열을 빠르게 가져옵니다.

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB원래의
2016-07-25 08:43:121052검색

有个猜用户喜欢的功能,用户可以通过点击换一组,来刷新推荐的内容。

先通过数据库查询,得到前1000条数据,然后随机去除4条。

程序写完之后,发现运行的很慢,每次刷新,都要等很久才出来。

代码如下:

  1. $arr = range(1, 100000);
  2. $start = time();
  3. for($i = 0; $i < 100; $i ){
  4. $key = mt_rand(0, 99999 - $i);
  5. $result[] = $arr[$key];
  6. unset($arr[$key]);
  7. sort($arr);
  8. }
  9. $end = time();
  10. echo $end - $start;
复制代码

上面的写法,用unset之后,必须进行排序。

unset只会删除键值,而key会保留。

经过改进之后的写法如下:

  1. $arr = range(1, 100000);
  2. $start = time();
  3. for($i = 0; $i < 100; $i ){
  4. $key = mt_rand(0, 99999 - $i);
  5. $result[] = array_splice($arr, $key, 1);
  6. }
  7. $end = time();
  8. echo $end - $start;
复制代码

效率提高了3-4倍。

그룹에서는 php


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.