Re: Lockless thread-safe accessor using blocks: how to?
Re: Lockless thread-safe accessor using blocks: how to?
- Subject: Re: Lockless thread-safe accessor using blocks: how to?
- From: WT <email@hidden>
- Date: Thu, 14 Apr 2011 11:57:15 -0300
Hi Jonathan,
thanks for replying.
On Apr 14, 2011, at 11:12 AM, Jonathan Taylor wrote:
> I am afraid I am not completely sure what you mean by your first problem,
That's ok. As I said, it's easy to fix. I don't want to get sidetracked here by going through it in detail. If you'd like to discuss that problem in more detail, we can do it off the list.
> but hopefully my answer to your second one sidesteps your concern there. In answer to your second (once I had parsed out the two different uses of the word "block" in what you said!)...
Yeah, the use of 'block' as both a verb and a noun is a bit confusing. Blame Apple for that... :)
> If I understand you correctly, what you're saying about your variable "__block SomeObjType foo" is not true. Regardless of the __block qualifier, foo is effectively a stack-based variable, so two simultaneously-executing threads have their own independent instance of that variable. There can be no "cross-talk" between the variables in separate threads - all you are doing is enabling the block that a given thread executes to have access to that specific thread's stack variable.
I'm afraid you're incorrect there. According to the documentation (or, more precisely, my understanding of the documentation), a variable qualified with __block starts in the stack but is moved to the heap, precisely because it's shared by all blocks capturing it and by all function scopes where it's declared. Therefore, I do not believe "two simultaneously-executing threads have their own independent instance of that variable" to be true.
> However I don't think you should need to do this anyway. I would change your code to something like this:
>
> - (SomeObjType) foo
> {
> dispatch_sync(queue,
> ^{
> // Code in this block ensures bah is valid
> if (nil == bah)
> {
> // Code to compute and store bah goes here
> }
> });
>
> return bah;
> }
I don't see how that could possibly work as is because bah is out of scope by the time the return statement is executed. Perhaps you meant that bah is an ivar or property declared in the same class as the accessor. I'm suddenly drawing a blank here because I considered this before and came to the conclusion that it wouldn't work but now I can't remember why I thought that way. I need to think this through a bit more.
Thanks again for your input.
WT_______________________________________________
Cocoa-dev mailing list (email@hidden)
Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com
Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden