Hi,

Yes something like that sounds good. Having to gc_cleanup() at places
within the code would be kind of messy, but perhaps calling something
like enable_mem_cleanup() at the beginning of the script could be a good
solution. Or perhaps just stealing ... ehhh borowing ... the
implementation from Python.

I believe that this is a problem where everybody who wants to use PHP
for more that small request/responce webscripts, is running into. The
problem and solution are to complicated for me to try to write a patch,
but I hope someone developing on the Zend Core will pick this subject up
and give it priority. (This should be the right list to find some
volunteer :)

Best regards,
Arnold


Matthias Pigulla wrote:
>  
>
>   
>> -----Ursprüngliche Nachricht-----
>> Von: Ants Aasma [mailto:[EMAIL PROTECTED] 
>>     
>
>   
>> That would indeed be too slow. The standard way to handle 
>> this, is to only check visibility periodically. That is how 
>> Java, .NET, Python and countless others do that. Check 
>> http://www.hpl.hp.com/personal/Hans_Boehm/gc/ for a sample of 
>> how an implementation might look like.
>>     
>
> The whole issue comes up regularly on various lists, e. g. Propel or Phing 
> suffer from it. Also see http://bugs.php.net/bug.php?id=33595. Working around 
> this in userland may be possible but is at least painful and messy.
>
> If the only problem is that detection is slow, wouldn't it be possible to add 
> a gc_cleanup() function that performs the scan? Those who use PHP in a 
> request/response environment need not care (everything is freed at the end of 
> the request). Those who don't and hit the problem regularly will find a good 
> place to make this call and certainly won't complain about the delay. 
>
> mp.
>
>   

Reply via email to