手机
当前位置:查字典教程网 >编程开发 >php教程 >phpQuery占用内存过多的处理方法
phpQuery占用内存过多的处理方法
摘要:phpQuery是一个用php实现的类似jQuery的开源项目,可以在服务器端以jQuery的语法形式解析网页元素。相对于正则或其它方式匹配...

phpQuery是一个用php实现的类似jQuery的开源项目,可以在服务器端以jQuery的语法形式解析网页元素。 相对于正则或其它方式匹配网页方式,phpQuery使用起来要方便的多。

在使用phpQuery采集网页时,遇到一个问题:在处理大量网页之后,phpQuery占用的内存数量非常惊人(很快就超过了1G),

比如这段代码:

复制代码 代码如下:

while (true) {

phpQuery::newDocumentFile($htmlFile);

// 处理网页元素...

echo memory_get_usage() . "n";

}

谨慎运行上面这段代码,它会很快用光你的内存。

经过查看phpQuery的源代码终于发现了问题所在,phpQuery在每处理一个网页就会产生一个DOMDocumentWrapper 对象,而每个DOMDocumentWrapper 对象会被保存在静态成员$documents中(phpQuery::createDocumentWrapper中),这个变量是一个数组,每解析一个网页数组元素就增加一个。

phpQuery::$documents[$wrapper->id] = $wrapper;

找到问题后,解决就很容易了,每次解析完一个网页,把phpQuery::$documents置空即可。

复制代码 代码如下:

while (true) {

phpQuery::newDocumentFile($htmlFile);

// 处理网页元素...

phpQuery::$documents = array();

echo memory_get_usage() . "n";

}

内存占用稳定了。

【phpQuery占用内存过多的处理方法】相关文章:

php中smarty区域循环的方法

php中smarty实现多模版网站的方法

PHP+shell实现多线程的方法

php简单实现快速排序的方法

两种php调用Java对象的方法

PHP实现多线程的两个方法

php使用curl打开https网站的方法

php限制ip地址范围的方法

php 防止表单重复提交方法

php使用for语句输出三角形的方法

精品推荐
分类导航