Yes, the question was pointed in another way, the destructors are not called 
until the last reference to an object has been removed, but if you store a 
reference in an array so you lately return a reference to the already loaded 
instance instead of creating an aliasing of that instance, then you get the 
undesirable behavior that the object is never destroyed until the script 
ends, because there is always a reference in that array and you can not check 
when references are removed in any way.
And leaving the array growing while each object that exists in a huge database 
is slowly loaded and never unloaded, is not an option.

Leo

On Tuesday 10 May 2005 11:26, you wrote:
> Leonardo Pedretti wrote:
> > It would not be such a problem to write something that does the same task
> > through a static or global function, but unfortunately it is impossible,
> > due to the following: you can build a cache in an array, then in a
> > __new() function you could check if the requested object is already
> > loaded and return a reference. However, if this is the case, objects that
> > enter the cache never leave it because they are still referenced in the
> > array when all other references have gone, so they never destruct, except
> > when the array is destroyed at program's end.
>
> PHP5 has destructors ...
>
> regards,
> Lukas

-- 

Leonardo Pedretti
Axon Sistemas
Líder de Equipo Proyecto Basalto

--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to