看到这个答案是她多年没有得出结论,最后更新!我现在遇到了类似的问题,结果发现DOMXPath只是泄漏了内存,你无法控制它.我还没有搜索到目前为止在bug.php.net上是否报告过这种情况(这可能对以后编辑有用).
我找到问题的“工作”解决方案只是解决方法.基本思想是将DOMXPath :: query()返回的DOMNodeList Traversable替换为包含相同节点的另一个.
最合适的解决方法是使用DOMXPathElementsIterator,它允许您在没有内存泄漏的情况下查询问题中的具体xpath表达式:
$nodes = new DOMXPathElementsIterator($this->dom, "//span[@class='ckass']");
foreach ($nodes as $span) {
...
}
此类现在是the development version of Iterator-Garden的一部分,$nodes是所有< span>的迭代器. DOMElements.
此解决方法的缺点是xpath结果限制为SimpleXMLElement::xpath()结果(这与DOMXPath :: query()不同),因为它在内部用于防止内存泄漏.
希望这是有用的,即使问题真的很老.它在类似的情况下帮助了我.
只有在不再引用(使用)对象时才调用垃圾收集清理圈.
例如,如果您为同一个DOMDocument重新创建一个新的DOMXPath对象(请记住它已连接到仍然存在的DOMDocument),听起来就像是您的内存“泄漏”.你只需要使用越来越多的内存.
相反,您可以在重复使用DOMDocument对象时重复使用现有的DOMXPath对象.试一试:
//Loaded outside of loop
$this->dom = new DOMDocument();
$xpath = new DOMXPath($this->dom);
//Inside Loop
$this->dom->loadHTML($output);
$nodes = $xpath->query("//span[@class='ckass']");