digitalmars.D.learn - Using ReadWriteMutex with synchronized{} ?
- E.S. Quinn (9/9) Oct 06 2013 I need to share an associative array between two threads, and to
- =?UTF-8?B?U8O2bmtlIEx1ZHdpZw==?= (14/23) Oct 07 2013 Using "synchronized" should work using the reader/writer properties:
I need to share an associative array between two threads, and to
that extent I'd like to make the whole thing synchronized. And
I'd like to use the built-in synchronized{} blocks, and I'd also
like to use the ReadWriteMutex from core.sync.rwmutex, since it
seems pretty much tailor-made for this sort of thing.
Is it possible to, for example, tell D that I want the enclosing
class synchronized with a ReadWriteMutex, and then specifcy which
functions need a reader lock and which need writer locks? Or will
I have to lock and unlock the mutex manually?
Oct 06 2013
Am 06.10.2013 23:25, schrieb E.S. Quinn:
I need to share an associative array between two threads, and to that
extent I'd like to make the whole thing synchronized. And I'd like to
use the built-in synchronized{} blocks, and I'd also like to use the
ReadWriteMutex from core.sync.rwmutex, since it seems pretty much
tailor-made for this sort of thing.
Is it possible to, for example, tell D that I want the enclosing class
synchronized with a ReadWriteMutex, and then specifcy which functions
need a reader lock and which need writer locks? Or will I have to lock
and unlock the mutex manually?
Using "synchronized" should work using the reader/writer properties:
---
auto rwmutex = new ReadWriteMutex;
synchronized (rwmutex.reader) {
// do something that reads from the protected memory area
}
synchronized (rwmutex.writer) {
// do something that reads/writes from/to the protected memory area
}
---
You'll have to synchronize inside of class methods according to
read/write though, AFAIK. "synchronized class" works only for the simple
case of all public methods being synchronized the same way.
Oct 07 2013








=?UTF-8?B?U8O2bmtlIEx1ZHdpZw==?= <sludwig outerproduct.org>