に、私たちは "ロック" の定義を見ることができます:implementions()は次のよう<a href="https://golang.org/src/sync/rwmutex.go" rel="nofollow noreferrer">src/sync/rwmutex.go</a>ファイルにgolang
func (rw *RWMutex) Lock() {
if race.Enabled {
_ = rw.w.state
race.Disable()
}
// First, resolve competition with other writers.
rw.w.Lock()
// Announce to readers there is a pending writer.
r := atomic.AddInt32(&rw.readerCount, -rwmutexMaxReaders) + rwmutexMaxReaders
// Wait for active readers.
if r != 0 && atomic.AddInt32(&rw.readerWait, r) != 0 {
runtime_Semacquire(&rw.writerSem)
}
if race.Enabled {
race.Enable()
race.Acquire(unsafe.Pointer(&rw.readerSem))
race.Acquire(unsafe.Pointer(&rw.writerSem))
}
}
は、だから私は本当に何
atomic.AddInt32(&rw.readerCount, -rwmutexMaxReaders) + rwmutexMaxReaders
この文を疑問に思います手段。そしてそれが言うように、どのように読者に発表?それを理解する方法?
rw.readerCount <= rwmutexMaxReadersなので、rw.readerCount-rwmutexMaxReadersは、readerCountを0またはnegativ(信号)にします。 rwmutxMaxReadersを追加すると、rはreaderWaitの実数と等しくなります。 – Volker