Need for Speed (postscript)

Mark Smith mark at maseurope.net
Mon Jul 16 05:50:43 EDT 2007


On 16 Jul 2007, at 07:26, Jim Ault wrote:

> On 7/15/07 8:37 PM, "Ludovic Thébault"  
> <ludovic.thebault at laposte.net> wrote:
>
>> On Sun, 15 Jul 2007 20:58:32 +0100, Beynon, Rob wrote:
>>
>> Hello, try to append the result to a file, it's a lot faster :
>
> Caution:  My limited experience with appending to log files is that  
> the
> larger the file size, the slower the append.

I guess this must have to do with how much RAM is available vs how  
much disc space is needed.

I just did this benchmark (with some nonce data):

on toFile
   put  
"10000,10001,10002,10003,10004,10005,10006,10007,10008,10009,100010"  
into tStr
   put the tempName into tFile
   open file tFile for append
   set cursor to watch
   put the millisecs into tStart

   repeat 1000000
     write tStr & cr to file tFile
   end repeat
   close file tFile
   put URL ("file:" & tFile) into tOutput
   delete file tFile
   put the millisecs - tStart
end toFile

on toVariable
   put  
"10000,10001,10002,10003,10004,10005,10006,10007,10008,10009,100010"  
into tStr
   set cursor to watch

   put the millisecs into tStart

   repeat 1000000
     put tStr & cr after tOutput
   end repeat

   put the millisecs - tStart
end toVariable

tOutput ends up at 67MB in both cases, and 'toFile' took just over 5  
seconds, whereas 'toVariable' took just over 40 seconds.
This is on a Mac PBG4 with 768MB RAM.

This could be useful to know when building up large lists.

Best,

Mark


More information about the use-livecode mailing list