在PHP中,对于文件的读取时,最快捷的方式莫过于使用一些诸如file、file_get_contents之类的函数,简简单单的几行代码就能很漂亮的完成我们所需要的功能。但当所操作的文件是一个比较大的文件时,这些函数可能就显的力不从心,下面将从一个需求入手来说明对于读取大文件时,常用的操作方法。
需求 有一个800M的日志文件,大约有500多万行, 用PHP返回最后几行的内容。 实现方法
1. 直接采用file函数来操作
注:由于 file函数是一次性将所有内容读入内存,而PHP为了防止一些写的比较糟糕的程序占用太多的内存而导致系统内存不足,使服务器出现宕机,所以默认情况下限制只能最大使用内存16M,这是通过PHP.ini里的memory_limit = 16M来进行设置,这个值如果设置-1,则内存使用量不受限制. 下面是一段用file来取出这具文件最后一行的代码.整个代码执行完成耗时 116.9613 (s).
<div class="codetitle"><a style="CURSOR: pointer" data="38151" class="copybut" id="copybut38151" onclick="doCopy('code38151')"> 代码如下: