php内存泄漏


Memory leak in php

我在理解为什么我的代码的这一部分会导致内存泄漏时遇到问题:

for($i=0; $i<count($values); $i++){
        $values[$i] = addslashes($values[$i]);
}

为了将代码放在上下文中,我有一个以前构建的名为values的数组,它包含要插入数据库的所有值。所有字段都是字符串,所以我需要转义所有字段,对于这个应用程序来说,addslash或mysql_real_eescape_string是一个不错的选择imo。

现在奇怪的是,一旦我添加了上面显示的部分,我就会收到这样的消息:

PHP Fatal error:  Allowed memory size of 134217728 bytes exhausted (tried to allocate 24 bytes)

我知道这会导致内存泄漏,但我不知道为什么。

深入挖掘,我评论掉了for循环中唯一的一行,留下for语句只是为了好奇,泄漏就消失了。你知道这可能意味着什么吗?

PS:字符串都是UTF8编码的,这可能是个问题吗?

编辑:

数组包含如下内容:

Array ( 
    [dossier] => 002A 
    [permis] => 
    [adresse] => 18, rue Bellevue
    [ville] => Ste-Anne-des-Lacs (Québec)
    [province] =>
    [code_postal] => J0R 1B0
    [numero_centrale] => N/A
    [routes] => De la Gare, droite chemin Avila jusqu'au bout et droite chemin Ste-Anne-des-lacs sur 1,8 km et droite sur Bellevue.
) 

您的数组有字符串键,但您正在检查/分配数字键。正如@nickl所指出的,每次添加数字键时,count($values)都会增加一,因此会有一个无限循环。因此记忆枯竭。

使用调试器进行检查,或者更好的方法是切换到foreach循环或array_*函数之一(array_walk()array_map()等,具体取决于您要执行的操作)。

@Jeremy正确地指出,不应该使用addslashes()来转义字符串。看看mysqli_real_escape_string()(正如他所建议的),或者更好的是,如果可以的话,考虑使用PDO

请尝试使用array_walk。

此外,不要指望每个循环。在将计数放入循环条件之前先获取它。由于这是针对数据库的,因此您实际上应该使用:mysqli_real_escape_string