1
0
mirror of https://github.com/charlienet/go-mixed.git synced 2025-07-18 00:22:41 +08:00

4 Commits

Author SHA1 Message Date
1abde30d8f locker 2024-05-28 04:17:26 +08:00
822932fe15 use base locker 2024-05-28 04:14:08 +08:00
85c5a611e1 bbb 2024-05-28 04:12:50 +08:00
fe5c0b54b6 locker 2024-05-28 04:08:50 +08:00
6 changed files with 70 additions and 72 deletions

View File

@ -2,22 +2,21 @@ package bloom
import (
"context"
"sync"
"github.com/bits-and-blooms/bitset"
"github.com/charlienet/go-mixed/locker"
)
type memStore struct {
size uint
set *bitset.BitSet // 内存位图
lock locker.RWLocker // 同步锁
set *bitset.BitSet // 内存位图
lock sync.RWMutex // 同步锁
}
func newMemStore(size uint) *memStore {
return &memStore{
size: size,
set: bitset.New(size),
lock: locker.RWLocker{},
}
}

View File

@ -1,14 +1,9 @@
package locker
var _ RWLocker = &emptyLocker{}
var _ Locker = &emptyLocker{}
var _ rwLocker = &emptyLocker{}
var _ locker = &emptyLocker{}
var EmptyLocker = &emptyLocker{}
type emptyLocker struct{}
func NewEmptyLocker() *emptyLocker {
return &emptyLocker{}
type emptyLocker struct {
}
func (l *emptyLocker) RLock() {}

View File

@ -2,14 +2,16 @@ package locker
import "sync"
type Locker interface {
type locker interface {
Lock()
Unlock()
TryLock() bool
}
type RWLocker interface {
Locker
type rwLocker interface {
Lock()
Unlock()
TryLock() bool
RLock()
RUnlock()
TryRLock() bool
@ -18,3 +20,7 @@ type RWLocker interface {
func NewLocker() *sync.Mutex {
return &sync.Mutex{}
}
func NewRWLocker() *sync.RWMutex {
return &sync.RWMutex{}
}

View File

@ -1,7 +0,0 @@
package locker
import "sync"
func NewRWLocker() *sync.RWMutex {
return &sync.RWMutex{}
}

View File

@ -1,12 +0,0 @@
package locker
import "testing"
func TestRWLokcer(t *testing.T) {
l := NewRWLocker()
l.RLock()
t.Log(l.TryRLock())
l.RUnlock()
}

View File

@ -3,94 +3,111 @@ package locker
import (
"log"
"sync"
"github.com/charlienet/go-mixed/redis"
)
type WithLocker struct {
once sync.Once
mu Locker
var empty = &emptyLocker{}
type Locker struct {
once sync.Once
distributedLocker DistributedLocker // 分布式锁
mu locker
}
func (w *WithLocker) Synchronize() {
if w.mu == nil || w.mu == EmptyLocker {
func (w *Locker) WithRedis(key string, rdb redis.Client) *Locker {
return w
}
func (w *Locker) WithDistributedLocker(d DistributedLocker) *Locker {
return w
}
func (w *Locker) Synchronize() *Locker {
if w.mu == nil || w.mu == empty {
w.mu = NewLocker()
}
return w
}
func (w *WithLocker) Lock() {
w.ensureLocker().Lock()
func (w *Locker) Lock() {
w.ensureLocker().mu.Lock()
}
func (w *WithLocker) Unlock() {
w.ensureLocker().Unlock()
func (w *Locker) Unlock() {
w.ensureLocker().mu.Unlock()
}
func (w *WithLocker) TryLock() bool {
return w.ensureLocker().TryLock()
func (w *Locker) TryLock() bool {
return w.ensureLocker().mu.TryLock()
}
func (w *WithLocker) ensureLocker() Locker {
func (w *Locker) ensureLocker() *Locker {
w.once.Do(func() {
if w.mu == nil {
w.mu = EmptyLocker
w.mu = empty
}
})
return w.mu
return w
}
type WithSpinLocker struct {
WithLocker
type SpinLocker struct {
Locker
}
func (w *WithSpinLocker) Synchronize() {
if w.mu == nil || w.mu == EmptyLocker {
func (w *SpinLocker) Synchronize() {
if w.mu == nil || w.mu == empty {
w.mu = NewSpinLocker()
}
}
type WithRWLocker struct {
type RWLocker struct {
once sync.Once
mu RWLocker
mu rwLocker
}
func (w *WithRWLocker) Synchronize() {
if w.mu == nil || w.mu == EmptyLocker {
log.Println("初始化有效锁")
func (w *RWLocker) Synchronize() *RWLocker {
if w.mu == nil || w.mu == empty {
w.mu = NewRWLocker()
}
return w
}
func (w *WithRWLocker) Lock() {
w.ensureLocker().Lock()
func (w *RWLocker) Lock() {
w.ensureLocker().mu.Lock()
}
func (w *WithRWLocker) TryLock() bool {
return w.ensureLocker().TryLock()
func (w *RWLocker) TryLock() bool {
return w.ensureLocker().mu.TryLock()
}
func (w *WithRWLocker) Unlock() {
w.ensureLocker().Unlock()
func (w *RWLocker) Unlock() {
w.ensureLocker().mu.Unlock()
}
func (w *WithRWLocker) RLock() {
w.ensureLocker().RLock()
func (w *RWLocker) RLock() {
w.ensureLocker().mu.RLock()
}
func (w *WithRWLocker) TryRLock() bool {
return w.ensureLocker().TryRLock()
func (w *RWLocker) TryRLock() bool {
return w.ensureLocker().mu.TryRLock()
}
func (w *WithRWLocker) RUnlock() {
w.ensureLocker().RUnlock()
func (w *RWLocker) RUnlock() {
w.ensureLocker().mu.RUnlock()
}
func (w *WithRWLocker) ensureLocker() RWLocker {
func (w *RWLocker) ensureLocker() *RWLocker {
w.once.Do(func() {
if w.mu == nil {
log.Println("初始化一个空锁")
w.mu = EmptyLocker
w.mu = empty
}
})
return w.mu
return w
}