diff options
author | Thiago Macieira <thiago.macieira@intel.com> | 2013-09-11 16:25:37 -0700 |
---|---|---|
committer | The Qt Project <gerrit-noreply@qt-project.org> | 2013-09-13 19:11:48 +0200 |
commit | c1c715f800d3c79eed8305f4b4be9bff8a81fda3 (patch) | |
tree | b7fb9e385d861d5d1c94b918d4165179ca95a376 /src | |
parent | d7e424ee6686f663f5134666e09c2875bb3e42b6 (diff) | |
download | qtbase-c1c715f800d3c79eed8305f4b4be9bff8a81fda3.tar.gz |
Optimize QBitArray::count(bool)
Ever since 76e0223619da02911d02813961ef631a5e02d826, qPopulationCount
was extracted from QBitArray and moved elsewhere. That unfortunately
meant that the 24-bit loads are completely useless, since
qPopulationCount always operates on 32 bits.
Instead, do a full loop on 32-bit and then do 16-bit and finally 8-bit
(for which there are qPopulationCount overloads).
Change-Id: If945609f075095257d12877c39434909ac190e54
Reviewed-by: Olivier Goffart <ogoffart@woboq.com>
Reviewed-by: Marc Mutz <marc.mutz@kdab.com>
Diffstat (limited to 'src')
-rw-r--r-- | src/corelib/tools/qbitarray.cpp | 29 |
1 files changed, 12 insertions, 17 deletions
diff --git a/src/corelib/tools/qbitarray.cpp b/src/corelib/tools/qbitarray.cpp index fb60534495..42e29f641c 100644 --- a/src/corelib/tools/qbitarray.cpp +++ b/src/corelib/tools/qbitarray.cpp @@ -169,30 +169,25 @@ QBitArray::QBitArray(int size, bool value) int QBitArray::count(bool on) const { int numBits = 0; - int len = size(); -#if 0 - for (int i = 0; i < len; ++i) - numBits += testBit(i); -#else const quint8 *bits = reinterpret_cast<const quint8 *>(d.data()) + 1; - while (len >= 32) { + + // the loops below will try to read from *end + // it's the QByteArray implicit NUL, so it will not change the bit count + const quint8 *const end = reinterpret_cast<const quint8 *>(d.end()); + + while (bits + 3 <= end) { quint32 v = quint32(bits[0]) | (quint32(bits[1]) << 8) | (quint32(bits[2]) << 16) | (quint32(bits[3]) << 24); - len -= 32; bits += 4; numBits += int(qPopulationCount(v)); } - while (len >= 24) { - quint32 v = quint32(bits[0]) | (quint32(bits[1]) << 8) | (quint32(bits[2]) << 16); - len -= 24; - bits += 3; + if (bits + 1 < end) { + quint16 v = quint16(bits[0]) | (quint16(bits[1]) << 8); + bits += 2; numBits += int(qPopulationCount(v)); } - while (len > 0) { - --len; - if (bits[len / 8] & (1 << (len & 7))) - ++numBits; - } -#endif + if (bits < end) + numBits += int(qPopulationCount(bits[0])); + return on ? numBits : size() - numBits; } |