lib/uint64set: optimize bucket16.addMulti a bit

This commit is contained in:
Aliaksandr Valialkin 2021-03-16 21:08:19 +02:00
parent 3caac5edd4
commit 1cfe3f872f

View File

@ -854,16 +854,21 @@ func (b *bucket16) add(x uint16) bool {
func (b *bucket16) addMulti(a []uint64) int { func (b *bucket16) addMulti(a []uint64) int {
count := 0 count := 0
bits := b.bits if b.bits == nil {
if bits == nil {
// Slow path // Slow path
for _, x := range a { for i, x := range a {
if b.add(uint16(x)) { if b.add(uint16(x)) {
count++ count++
} }
if b.bits != nil {
a = a[i+1:]
goto fastPath
} }
} else { }
// Fast path return count
}
fastPath:
bits := b.bits
for _, x := range a { for _, x := range a {
wordNum, bitMask := getWordNumBitMask(uint16(x)) wordNum, bitMask := getWordNumBitMask(uint16(x))
if bits[wordNum]&bitMask == 0 { if bits[wordNum]&bitMask == 0 {
@ -871,7 +876,6 @@ func (b *bucket16) addMulti(a []uint64) int {
count++ count++
} }
} }
}
return count return count
} }