synchronized (this[.classinfo]) in druntime and phobos

Alex Rønne Petersen alex at lycus.org
Tue May 29 14:59:14 PDT 2012


On 29-05-2012 23:31, Andrei Alexandrescu wrote:
> On 5/29/12 1:32 AM, deadalnix wrote:
>> I already did some comment about this.
>>
>> Making any object synchronization is a very bad design decision. It is
>> deadlock prone, it is liquid lock prone, it cause an overhead on any
>> object, and even worse, it is useless most of the time as D promote
>> thread locality (which is very good).
>
> Actually I think such a characterization is superficial and biased to
> the extent it becomes wrong.

Really ? I think he's spot on.

>
> Locks are deadlock-prone by design, whether used with objects or with
> classic procedural programs. In fact they are better confined to objects
> because the association between the protected data and the
> synchronization object is clear.

There is no doubt that synchronization of any kind is hard and 
error-prone no matter how you do it. But do you really think that the 
situation is made better by allowing locking on *anything*, meaning that 
locks are effectively resources shared publicly?

Besides, what's wrong with core.sync.mutex?

>
>> OOP and concurrency are 2 orthogonal topics, and should be handled as
>> such.
>
> Well there would be active objects that contradict that. But really it
> is very natural to encapsulate together some data along with the mutex
> that must be acquired to manipulate it. There are known issues with
> inheritance, but they are not introduced by the approach, only exposed
> by it.
>
>
> Andrei

-- 
Alex Rønne Petersen
alex at lycus.org
http://lycus.org


More information about the Digitalmars-d mailing list