phobos / tango / ares
Johan Granberg
lijat.meREM at OVE.gmail.com
Sun Feb 11 00:24:34 PST 2007
Sean Kelly wrote:
> kris wrote:
>> Charles D Hixson wrote:
>>> I'm not sure whether you were quoting the documentation, or reporting
>>> your understanding. If you were quoting the documentation, I think it
>>> needs editing.
>>
>> From the doc: "Please note that the class itself is stateful, and
>> therefore a single instance is not shareable across multiple threads."
>>
>> Thus, it is considered unwise to share a single instance of Sprint
>> across multiple threads. However, multiple threads /can/ share a single
>> instance if they follow this pattern:
>>
>> synchronized (GlobalSprint)
>> GlobalSprint ("do my formatting", with, these, args);
>>
>> This is a fairly standard mechanism in D for sharing resources across
>> threads, and it's what I had referred to.
>
> For what it's worth, Tango also provides thread-local storage, and while
> it isn't ideal from a semantic standpoint (a bona-fide 'local' storage
> class would be much nicer), it's an option worth considering. It could
> be used like so:
>
> auto TLSPrint = new ThreadLocal!(Sprint);
> // do this in each thread
> TLSPrint.val = new Sprint;
>
> // use the local Sprint instance
> TLSPrint.val()( "do my formatting", with, these, args );
>
> Accessing a TLS value tyically amounts to a few pointer dereferences so
> it's far less costly than acquiring a mutex, which may or may not be
> important to you.
>
> As a side-note... Tango currently provides 64 TLS "slots". This amount
> is fixed mostly to keep performance as high as possible, but it could
> easily be increased if it turns out not to be enough.
>
>
> Sean
What happens when you run out of slots?
Would it be possible to have a dynamic amount of slots (doubling whenever
there is to few)?
More information about the Digitalmars-d-learn
mailing list