1 Star 0 Fork 3

Fengzhi/gkit

forked from menuiis/gkit 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
util.go 1.08 KB
一键复制 编辑 原始数据 按行查看 历史
menuis 提交于 2024-04-22 10:18 +08:00 . init
// Copyright 2021 ByteDance Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package skipmap
import (
"gitee.com/menciis/gkit/internal/wyhash"
"gitee.com/menciis/gkit/sys/fastrand"
_ "unsafe" // for linkname
)
const (
maxLevel = 16
p = 0.25
defaultHighestLevel = 3
)
func hash(s string) uint64 {
return wyhash.Sum64String(s)
}
//go:linkname cmpstring runtime.cmpstring
func cmpstring(a, b string) int
func randomLevel() int {
level := 1
for fastrand.Uint32n(1/p) == 0 {
level++
}
if level > maxLevel {
return maxLevel
}
return level
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/fengzhi_1/gkit.git
git@gitee.com:fengzhi_1/gkit.git
fengzhi_1
gkit
gkit
b6285053065d

搜索帮助