feat(完整功能): 以Apache License 2.0协议开源

This commit is contained in:
2025-09-24 02:58:49 +08:00
parent 1a53a5ab8f
commit 0d90c09d71
5 changed files with 951 additions and 1 deletions

View File

@@ -1,2 +1,50 @@
# klock
一个基于键的高性能、并发安全的 Go 语言读写锁
一个键级别的高性能、并发安全的 Go 语言读写锁
klock 可以为每一个数据(由一个唯一的“键”来标识)提供一把专属的锁。在高并发时,这意味着操作不同数据的任务可以并行,互不影响,从而大幅提升程序性能。它特别适合需要精细化控制单个资源访问的场景。
# 安装指南
```shell
go get -u github.com/xiaoqidun/klock
```
# 快速开始
下面的示例演示了 klock 的核心作用:保护一个共享计数器在并发修改下的数据一致性
```go
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](https://github.com/xiaoqidun/klock/blob/main/LICENSE) 授权协议