mirror of
https://github.com/xiaoqidun/klock.git
synced 2025-10-11 11:40:23 +08:00
0d90c09d719dd34f977a7468b1b17af7d1ea64fa
klock
一个键级别的高性能、并发安全的 Go 语言读写锁
klock 可以为每一个数据(由一个唯一的“键”来标识)提供一把专属的锁。在高并发时,这意味着操作不同数据的任务可以并行,互不影响,从而大幅提升程序性能。它特别适合需要精细化控制单个资源访问的场景。
安装指南
go get -u github.com/xiaoqidun/klock
快速开始
下面的示例演示了 klock 的核心作用:保护一个共享计数器在并发修改下的数据一致性
package main
import (
"fmt"
"sync"
"github.com/xiaoqidun/klock"
)
func main() {
// 1. 创建 klock 实例
kl := klock.New()
// 2. 准备一个共享的计数器和用于它的锁的键
var counter int
lockKey := "counter_lock"
// 3. 模拟高并发修改计数器
var wg sync.WaitGroup
concurrency := 1000 // 增加并发量以突显问题
wg.Add(concurrency)
for i := 0; i < concurrency; i++ {
go func() {
defer wg.Done()
kl.Lock(lockKey) // 获取锁
counter++ // 安全修改
kl.Unlock(lockKey) // 释放锁
}()
}
wg.Wait()
// 4. 验证结果
// 如果没有 klock 保护,由于竞态条件,counter 的最终值将是一个小于1000的不确定数字。
// 有了 klock,结果一定是 1000。
fmt.Printf("最终结果: %d\n", counter)
}
授权协议
本项目使用 Apache License 2.0 授权协议
Description
Languages
Go
100%