https://bugs.kde.org/show_bug.cgi?id=359305

--- Comment #1 from Sergio Martins <smart...@kde.org> ---
Your first example allocates once (due to keys() call), and it should allocate
0.
Use instead: for (auto it = someMap.cbegin(), end = someMap.cend(); it != end;
++it)

Your second example allocates twice (due to keys call) and it should allocate
once, construct the set manually instead.

This is what happens when you call keys():
template <class Key, class T>
Q_OUTOFLINE_TEMPLATE QList<Key> QHash<Key, T>::keys() const
{
    QList<Key> res;
    res.reserve(size());
    const_iterator i = begin();
    while (i != end()) {
        res.append(i.key());
        ++i;
    }
    return res;
}

You would be iterating twice instead of iterating the map directly.
I can update the README and make it more clear.

-- 
You are receiving this mail because:
You are watching all bug changes.

Reply via email to