微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在大型数组上具有负偏移量的array_slice

如何解决在大型数组上具有负偏移量的array_slice

| 由于我在这里不讨论的原因,我被迫解析文件的大目录(我们正在谈论100.000 文件列表作为数组返回。 我已经在缓存文件列表,问题是array_slice。 是的,因为有一个陷阱,所以该文件列表必须是“分页的”,并在16个块中返回它们。 我正在做的是这样的:
$items_per_page = 16;
$offset = ($current_page * $items_per_page) + $items_per_page;
array_slice($array,-$offset,$items_per_page);
很容易看出,在几页中我们将有很多抵消额。 同样从第四页开始(偏移= -80),对性能产生了巨大影响。 我可以使用什么代替array_slice来实现这种数组分页? 谢谢     

解决方法

        如果对数组进行数字索引(不跳过数字),则可以尝试使用for循环。
$items_per_page = 16;
$offset = ($current_page * $items_per_page) + $items_per_page;
$chunk = array();
for($i=$offset;$i<$offset+$items_per_page;$i++){
    $chunk[] = $files[$i];
}
编辑: 我只是做了一些基准测试来了解一个想法。在我们的服务器上,该数组包含一百万个项目,每个项目处理100次,array_slice()花费了2.5689ms的处理时间。使用for循环花费了0.0031ms。     ,        考虑创建,填充和操作数据库表,而不是在内存中完成所有这些操作。索引可以使您以合理的性能对文件进行分页。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。