ID:               39011
 User updated by:  php_bug dot email at email dot digiways dot com
 Reported By:      php_bug dot email at email dot digiways dot com
 Status:           Open
 Bug Type:         Arrays related
 Operating System: Windows XP
 PHP Version:      5.1.6
 New Comment:

Documentation describes that parameters are passed to functions by
value by default. And since the behaviour you are talking about is not
documented anywhere, it is definitely a bug.

So, I suggest you read PHP documentation starting with
http://www.php.net/manual/en/functions.arguments.php
which clearly states:
===
By default, function arguments are passed by value (so that if you
change the value of the argument within the function, it does not get
changed outside of the function). If you wish to allow a function to
modify its arguments, you must pass them by reference.
===

and then explain it again why the problem described above is not a bug
although it does not do what PHP documentation states it does.


Previous Comments:
------------------------------------------------------------------------

[2006-10-01 22:34:35] judas dot iscariote at gmail dot com

again, THIS IS NOT A BUG ยก!

but yes,this behaviuor should be described in the documentation I
think.

I still think this kind of code should raise an E_WARNING or something
( the idea was proposed a while ago, but refused)

------------------------------------------------------------------------

[2006-10-01 22:12:20] plyrvt at mail dot ru

This bug can be described shortly:
"Existance of a reference to the element of an array prevents this
element to be passed by value as long as any reference point to it"

------------------------------------------------------------------------

[2006-10-01 22:02:06] php_bug dot email at email dot digiways dot com

Actually this is not just about foreach, this is the generic problem
with references.
Apparently if you have a reference to an array element, then when you
pass that array to a function and modify that element in the function,
then the external array is modified as well, and not just the copy
passed to the function.

A small example which shows the problem:
        $myarray = array( 'mykey' => 'foo' );
        function doit($tmp) { $tmp['mykey'] = 'bar'; }
        $value = &$myarray['mykey'];
        echo $myarray['mykey']."\n";
        doit($myarray);
        echo $myarray['mykey']."\n";

Once again - can anyone point to the documentation page which explains
this behaviour ?

------------------------------------------------------------------------

[2006-10-01 21:55:23] plyrvt at mail dot ru

If you add unset($val) after foreach, original array starts back to
work as expected:

<?php
$a['b']='foo';
function boo($_params){
        $_params['b'] = 'bar';
        echo $_params['b'];
}

foreach($a as $key => &$val) {}
unset($val);

        echo $a['b'];
        boo($a);
        echo $a['b'];
/*
foo
bar
foo
*/
?>

------------------------------------------------------------------------

[2006-10-01 21:39:58] plyrvt at mail dot ru

Confirm with 5.1.6:
<?php
$a['b']='foo';
function boo($_params){
        $_params['b'] = 'bar';
        echo $a['b'];
}

foreach($a as $key => &$val) {} // ?!

        echo $a['b'];
        boo($a);
        echo $a['b'];
?>

If you comment out `foreach` loop or remove & near `$val`, code works
OK. Loop does nothing and $val is *never* mentioned in code elsewhere.

------------------------------------------------------------------------

The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at
    http://bugs.php.net/39011

-- 
Edit this bug report at http://bugs.php.net/?id=39011&edit=1

Reply via email to