Исходники и презентации

This commit is contained in:
2025-05-23 07:26:39 +03:00
parent aa948179d5
commit 02d8430a3a
514 changed files with 13773 additions and 0 deletions

View File

@ -0,0 +1,123 @@
package main
import (
"sync/atomic"
"testing"
"time"
"github.com/stretchr/testify/assert"
)
type RWMutex struct {
// need to implement
}
func (m *RWMutex) Lock() {
// need to implement
}
func (m *RWMutex) Unlock() {
// need to implement
}
func (m *RWMutex) RLock() {
// need to implement
}
func (m *RWMutex) RUnlock() {
// need to implement
}
func TestRWMutexWithWriter(t *testing.T) {
var mutex RWMutex
mutex.Lock() // writer
var mutualExlusionWithWriter atomic.Bool
mutualExlusionWithWriter.Store(true)
var mutualExlusionWithReader atomic.Bool
mutualExlusionWithReader.Store(true)
go func() {
mutex.Lock() // another writer
mutualExlusionWithWriter.Store(false)
}()
go func() {
mutex.RLock() // another reader
mutualExlusionWithReader.Store(false)
}()
time.Sleep(time.Second)
assert.True(t, mutualExlusionWithWriter.Load())
assert.True(t, mutualExlusionWithReader.Load())
}
func TestRWMutexWithReaders(t *testing.T) {
var mutex RWMutex
mutex.RLock() // reader
var mutualExlusionWithWriter atomic.Bool
mutualExlusionWithWriter.Store(true)
go func() {
mutex.Lock() // another writer
mutualExlusionWithWriter.Store(false)
}()
time.Sleep(time.Second)
assert.True(t, mutualExlusionWithWriter.Load())
}
func TestRWMutexMultipleReaders(t *testing.T) {
var mutex RWMutex
mutex.RLock() // reader
var readersCount atomic.Int32
readersCount.Add(1)
go func() {
mutex.RLock() // another reader
readersCount.Add(1)
}()
go func() {
mutex.RLock() // another reader
readersCount.Add(1)
}()
time.Sleep(time.Second)
assert.Equal(t, int32(3), readersCount.Load())
}
func TestRWMutexWithWriterPriority(t *testing.T) {
var mutex RWMutex
mutex.RLock() // reader
var mutualExlusionWithWriter atomic.Bool
mutualExlusionWithWriter.Store(true)
var readersCount atomic.Int32
readersCount.Add(1)
go func() {
mutex.Lock() // another writer is waiting for reader
mutualExlusionWithWriter.Store(false)
}()
time.Sleep(time.Second)
go func() {
mutex.RLock() // another reader is waiting for a higher priority writer
readersCount.Add(1)
}()
go func() {
mutex.RLock() // another reader is waiting for a higher priority writer
readersCount.Add(1)
}()
time.Sleep(time.Second)
assert.True(t, mutualExlusionWithWriter.Load())
assert.Equal(t, int32(1), readersCount.Load())
}