This is funny, why isn't there a panic in this case? It clearly "works" as
in it doesn't deadlock or panics assuming a write lock isn't somehow mixed
incorrectly.


On Tue, Sep 22, 2020 at 3:56 PM 'Bryan C. Mills' via golang-nuts <
golang-nuts@googlegroups.com> wrote:

> Note that a lock on a sync.Mutex or sync.RWMutex is *not* held by a
> specific goroutine: it can be locked by one goroutine, then communicated by
> some other means (such as being sent on a channel) and unlocked on a
> *different* goroutine. (See also https://golang.org/issue/9201.)
>
> That is: these locks *cannot* be reentrant because they do not contain
> goroutine-specific metadata.
>
> I read through the docs for this type again, and noticed that while the
> documentation for the Unlock method seems very clear on this point, the
> documentation for the type itself is not. (I filed
> https://golang.org/issue/41555, for which you are welcome to contribute
> <https://golang.org/doc/contribute.html> a fix!)
>
> On Monday, September 21, 2020 at 8:26:46 AM UTC-4
> axel.wa...@googlemail.com wrote:
>
>> FTR, I still don't think the docs *are* ambiguous. The authoritative part
>> is
>>
>> If a goroutine holds a RWMutex for reading and another goroutine might
>>> call Lock, no goroutine should expect to be able to acquire a read lock
>>> until the initial read lock is released.
>>
>>
>> The rest is just additional explanation. This sentence alone is already
>> sufficient to define the behavior.
>>
>> On Mon, Sep 21, 2020 at 2:14 PM Axel Wagner <axel.wa...@googlemail.com>
>> wrote:
>>
>>> On Mon, Sep 21, 2020 at 2:06 PM Henrik Johansson <dahan...@gmail.com>
>>> wrote:
>>>
>>>> Ambiguous docs however aren't generally good in any way. This came up
>>>> as a consequence of real code being changed by a new very skilled developer
>>>> and there was quite a bit discussion that could have been avoided with
>>>> clearer docs.
>>>>
>>>
>>> I think it would be useful to be more explicit about the use-case then.
>>> As I said, I can't really fathom a situation where you'd *want* to do that
>>> and if you don't want it, I can't imagine how it would matter whether you
>>> can.
>>>
>>>
>>>>
>>>> We have sorted the issue I mostly wanted to confirm my suspicion wrt
>>>> nested read locks.
>>>>
>>>> On Mon, 21 Sep 2020, 13:31 Axel Wagner, <axel.wa...@googlemail.com>
>>>> wrote:
>>>>
>>>>> To elaborate a bit: You are correct in that there is a slight
>>>>> syntactic ambiguity whether "this prohibits" refers to the entire sentence
>>>>> ("if another goroutine might call Lock, then a second RLock might not be
>>>>> acquired"), or only to the second half. I would argue the rest of the
>>>>> section makes it clear that the second version is intended - "a goroutine
>>>>> can not expect a second RLock to be acquired. This prohibits…".
>>>>>
>>>>> But yes, it certainly can be argued that the ambiguity hides the
>>>>> possibility of nested RLocks when no other goroutine calls Lock. But even
>>>>> if then: Given that this would not be useful (an RLock without a 
>>>>> concurrent
>>>>> Lock is functionally a no-op, AIUI), but *can* lead to incorrect code if
>>>>> applied improperly, that possibility doesn't seem worthwhile to advertise
>>>>> further.
>>>>>
>>>>> So even if the docs are ambiguous, that hardly seems a problem.
>>>>>
>>>>> On Mon, Sep 21, 2020 at 12:58 PM Axel Wagner <
>>>>> axel.wa...@googlemail.com> wrote:
>>>>>
>>>>>> It only says that's excluded *if* you can have a concurrent Lock call.
>>>>>>
>>>>>> On Mon, Sep 21, 2020 at 12:48 PM Henrik Johansson <dahan...@gmail.com>
>>>>>> wrote:
>>>>>>
>>>>>>> Yes that's the canonical deadlock but doesn't the docs say
>>>>>>>
>>>>>>> "In particular, this prohibits recursive read locking"
>>>>>>>
>>>>>>> which it doesn't unless you mix reads and writes.
>>>>>>>
>>>>>>> I get that it's not advisable but it's not prohibited either or
>>>>>>> there would be a panic or something.
>>>>>>>
>>>>>>> On Mon, 21 Sep 2020, 12:30 Axel Wagner, <axel.wa...@googlemail.com>
>>>>>>> wrote:
>>>>>>>
>>>>>>>> (Note, FWIW, that in particular no write locks need to be *held*.
>>>>>>>> It's enough for Lock to be *called*, it doesn't have to have returned 
>>>>>>>> yet)
>>>>>>>>
>>>>>>>> On Mon, Sep 21, 2020 at 12:29 PM Axel Wagner <
>>>>>>>> axel.wa...@googlemail.com> wrote:
>>>>>>>>
>>>>>>>>> I feel like the docs are pretty precise in what they say and why.
>>>>>>>>>
>>>>>>>>> a blocked Lock call excludes new readers from acquiring the lock.
>>>>>>>>>
>>>>>>>>>
>>>>>>>>> This means, the following could happen:
>>>>>>>>> Goroutine 1 calls RLock, acquires a Read-Lock
>>>>>>>>> Goroutine 2 calls Lock, blocking
>>>>>>>>> Goroutine 1 calls RLock again, blocking (as no new read locks can
>>>>>>>>> be acquired while GR 2 is blocked).
>>>>>>>>> Thus, you get a deadlock.
>>>>>>>>>
>>>>>>>>> It also has a conditional on the section
>>>>>>>>>
>>>>>>>>> If a goroutine holds a RWMutex for reading and another goroutine
>>>>>>>>>> might call Lock […]
>>>>>>>>>
>>>>>>>>>
>>>>>>>>> So if you know that no other goroutine might call Lock
>>>>>>>>> concurrently, then yes, you can call RLock twice. I can't really 
>>>>>>>>> imagine a
>>>>>>>>> setting where you'd need an RWMutex and have that assurance and need
>>>>>>>>> recursive read locks. But there might be one.
>>>>>>>>>
>>>>>>>>> On Mon, Sep 21, 2020 at 12:16 PM Henrik Johansson <
>>>>>>>>> dahan...@gmail.com> wrote:
>>>>>>>>>
>>>>>>>>>>
>>>>>>>>>> https://golang.org/pkg/sync/#RWMutex
>>>>>>>>>>
>>>>>>>>>> Holds that this prohibits recursive read locks but why would it?
>>>>>>>>>> I understand that deadlocks can happen in case write locks are
>>>>>>>>>> held in between the read locks
>>>>>>>>>> but why can't a goroutine issue several RLock calls?
>>>>>>>>>>
>>>>>>>>>> It does actually work in the playground.
>>>>>>>>>> https://play.golang.org/p/nOehJaeikxA
>>>>>>>>>> Is this simply a recommendation or should the docs be updated to
>>>>>>>>>> clarify what this means?
>>>>>>>>>>
>>>>>>>>>>
>>>>>>>>>> --
>>>>>>>>>> You received this message because you are subscribed to the
>>>>>>>>>> Google Groups "golang-nuts" group.
>>>>>>>>>> To unsubscribe from this group and stop receiving emails from it,
>>>>>>>>>> send an email to golang-nuts...@googlegroups.com.
>>>>>>>>>> To view this discussion on the web visit
>>>>>>>>>> https://groups.google.com/d/msgid/golang-nuts/CAKOF696YKSGn3j%2BcyX7o0ukA7wnD2Kq19_QGefUoeMELUZGOWA%40mail.gmail.com
>>>>>>>>>> <https://groups.google.com/d/msgid/golang-nuts/CAKOF696YKSGn3j%2BcyX7o0ukA7wnD2Kq19_QGefUoeMELUZGOWA%40mail.gmail.com?utm_medium=email&utm_source=footer>
>>>>>>>>>> .
>>>>>>>>>>
>>>>>>>>> --
> You received this message because you are subscribed to the Google Groups
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to golang-nuts+unsubscr...@googlegroups.com.
> To view this discussion on the web visit
> https://groups.google.com/d/msgid/golang-nuts/e103440c-d05c-436a-bb19-c38ffe01a8can%40googlegroups.com
> <https://groups.google.com/d/msgid/golang-nuts/e103440c-d05c-436a-bb19-c38ffe01a8can%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
>

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/CAKOF697GsWgLppP6rxiYDeuTOyi_9tux18Tvex8CXysfVyEhvQ%40mail.gmail.com.

Reply via email to