On Tue, 05 Jun 2012 09:33:53 +0200
Michael Schnell <mschn...@lumino.de> wrote:

> On 06/05/2012 08:29 AM, Mattias Gaertner wrote:
> > yes it is relevant. If you have two memory managers you can not 
> > exchange strings and classes.
> Is cmem "the way to go" to unify the memory managers of a dynamic 
> library and the calling application ? (There seem more advanced free 
> alternatives written for Delphi, that might be usable with FPC.)
> 
> Will just "using" cmem both in the main program and in the library 
> automatically unify the memory managers ?

Under Linux: yes. I guess BSD, OS X
too. The Delphi alternatives work only on MS Windows.

 
> http://wiki.freepascal.org/Multithreaded_Application_Tutorial states:
> 
>    cmem,  // the c memory manager is on some systems much faster for 
> multi-threading
> 
> and
> 
> You can not use the -gh switch with the/cmem/  unit. The -gh switch uses the 
> heaptrc unit,
> which extends the heap manager. Therefore the*heaptrc*  unit must be 
> used*after*  the*cmem*  unit.
> 
> 
> 
> Should the FPC memory manager not be more optimized for FPC code then cmem ?

Yes, it normally is.
It was slower with multithreading on some systems. The FPC heap manager
was improved for OS X. Do some tests to find out which one is better for
your application.


Mattias

--
_______________________________________________
Lazarus mailing list
Lazarus@lists.lazarus.freepascal.org
http://lists.lazarus.freepascal.org/mailman/listinfo/lazarus

Reply via email to