refactor(common): 重构 bitset 和 log 包

- 移除了 github.com/scylladb/termtables 依赖
- 修改了 bitset 包,移除了未使用的代码和测试
- 修改了 log 包,移除了未使用的代码和测试
- 更新了 go.work 文件,添加了 bitset 和 log 包
This commit is contained in:
2025-07-02 22:31:54 +08:00
parent 8fb792b0f2
commit ffc39f5462
42 changed files with 6445 additions and 32 deletions

View File

@@ -0,0 +1,66 @@
# bitset32
[![Test](https://github.com/bits-and-blooms/bitset/workflows/Test/badge.svg)](https://github.com/pointernil/bitset32/actions?query=workflow%3ATest)
[en English](./README.md)
## 简介
`bitset32` 修改自 `"github.com/bits-and-blooms/bitset"`底层使用uint32存数据`bitset32` `bitset` 用法一致
如非必要请使用 ["github.com/bits-and-blooms/bitset"](https://github.com/bits-and-blooms/bitset)。
## Golang版本
```
go version go1.19.4 windows/amd64
```
## 安装
```
go get github.com/pointernil/bitset32
```
## 测试
```
go test
go test -cover
```
## 使用示意
```
package main
import (
"fmt"
"math/rand"
"github.com/pointernil/bitset32"
)
func main() {
fmt.Printf("! \n")
var b bitset32.BitSet32
// play some Go Fish
for i := 0; i < 100; i++ {
card1 := uint(rand.Intn(52))
card2 := uint(rand.Intn(52))
b.Set(card1)
if b.Test(card2) {
fmt.Println("Go Fish!")
}
b.Clear(card1)
}
// Chaining
b.Set(10).Set(11)
for i, e := b.NextSet(0); e; i, e = b.NextSet(i + 1) {
fmt.Println("The following bit is set:", i)
}
if b.Intersection(bitset32.New(100).Set(10)).Count() == 1 {
fmt.Println("Intersection works.")
} else {
fmt.Println("Intersection doesn't work???")
}
}
```