golang 实现redis 排行榜同分值情况下按时间升序排序
在排行榜中实现分数和时间排序 分数相同则按照时间排序
需求分析
- redis中zset的long为int64 转为十进制是19位
- 时间戳10位 毫秒时间戳13位 高位存分数7位 十进制 7位
- 8字节中拆分 最高位不可用 还剩43位 高22位存分数 低41位存时间戳
golang 代码
package main
import (
"fmt"
"sort"
"time"
)
var scores []int64
func main() {
sorts()
//bit()
}
func bit() {
fmt.Println(len(fmt.Sprintf("%d", 1<<9)))
fmt.Println(len(fmt.Sprintf("%d", 1<<41)))
fmt.Println(len(fmt.Sprintf("%d", 1<<23)))
fmt.Println(len("1000000"))
}
func sorts() {
now := time.Now().UnixMilli()
for i := 1; i < 10; i++ {
scores = append(scores, toScore(int64(i+100000), now))
}
sort.Slice(scores, func(i, j int) bool {
return scores[i] > scores[j]
})
for _, score := range scores {
fmt.Println(load(score))
//fmt.Println(score)
}
}
func toScore(point int64, periodEndTimestamp int64) (score int64) {
score = (score | point) << 41
score = score | periodEndTimestamp
return
}
func load(score int64) int64 {
return score >> 41
}
本文来自博客园,作者:vx_guanchaoguo0,转载请注明原文链接:https://www.cnblogs.com/guanchaoguo/p/16282661.html