后端开发|php教程
php,phpQuery
后端开发-php教程
phpQuery是一个用php实现的类似jQuery的开源项目,可以在服务器端以jQuery的语法形式解析网页元素。 相对于正则或其它方式匹配网页方式,phpQuery使用起来要方便的多。
在使用phpQuery采集网页时,遇到一个问题:在处理大量网页之后,phpQuery占用的内存数量非常惊人(很快就超过了1G),
比如这段代码:
php 仿卷皮源码,vscode同样的代码,ios设置ubuntu,tomcat线程使用,sqlite数据库被删,阿里一个前端框架作者月薪6k,四周实现爬虫网站视频,php 队列的实现,湘西seo优化厂商,网站图片切换js代码,分享类网页源码,zblog php单页模板lzw
while (true) {
phpQuery::newDocumentFile($htmlFile);
// 处理网页元素...
echo memory_get_usage() . "\n";
}
谨慎运行上面这段代码,它会很快用光你的内存。
经过查看phpQuery的源代码终于发现了问题所在,phpQuery在每处理一个网页就会产生一个DOMDocumentWrapper 对象,而每个DOMDocumentWrapper 对象会被保存在静态成员$documents中(phpQuery::createDocumentWrapper中),这个变量是一个数组,每解析一个网页数组元素就增加一个。
phpQuery::$documents[$wrapper->id] = $wrapper;
找到问题后,解决就很容易了,每次解析完一个网页,把phpQuery::$documents置空即可。
织梦源码怎么用,vscode主题排行榜,电脑 换成ubuntu,运行tomcat后404,java爬虫 原理,php 隐藏部分字符,seo第五课,网站源码放在哪里的,仿微头条网站资讯模板V3.0lzw
while (true) {
phpQuery::newDocumentFile($htmlFile);
// 处理网页元素...
phpQuery::$documents = array();
echo memory_get_usage() . "\n";
}
内存占用稳定了。
秒赞易语言源码下载,vscode调试edge闪退,ubuntu 运行ios,部署几个tomcat集群,爬虫怎么去学,php 保存用户名和密码,新都区seo优化推广,团购网站源码,小猪微信模板消息lzw