mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-12-14 16:12:15 +01:00
lib/uint64set: optimize bucket16.addMulti a bit
This commit is contained in:
parent
3caac5edd4
commit
1cfe3f872f
@ -854,23 +854,27 @@ func (b *bucket16) add(x uint16) bool {
|
||||
|
||||
func (b *bucket16) addMulti(a []uint64) int {
|
||||
count := 0
|
||||
bits := b.bits
|
||||
if bits == nil {
|
||||
if b.bits == nil {
|
||||
// Slow path
|
||||
for _, x := range a {
|
||||
for i, x := range a {
|
||||
if b.add(uint16(x)) {
|
||||
count++
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// Fast path
|
||||
for _, x := range a {
|
||||
wordNum, bitMask := getWordNumBitMask(uint16(x))
|
||||
if bits[wordNum]&bitMask == 0 {
|
||||
bits[wordNum] |= bitMask
|
||||
count++
|
||||
if b.bits != nil {
|
||||
a = a[i+1:]
|
||||
goto fastPath
|
||||
}
|
||||
}
|
||||
return count
|
||||
}
|
||||
fastPath:
|
||||
bits := b.bits
|
||||
for _, x := range a {
|
||||
wordNum, bitMask := getWordNumBitMask(uint16(x))
|
||||
if bits[wordNum]&bitMask == 0 {
|
||||
bits[wordNum] |= bitMask
|
||||
count++
|
||||
}
|
||||
}
|
||||
return count
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user