QHash: Add note about reference/iterator invalidation
It is mentioned in the porting docs, and in the class description of the _iterators_, but none of those are really natural places to look for the behavior of the container. So, let's add a general note/warning to the functions in question. Fixes: QTBUG-124195 Change-Id: Ic95e56f166df2c8067232dfb6b9cb5b05d6a4361 Reviewed-by: Thiago Macieira <thiago.macieira@intel.com> (cherry picked from commit 4c286d6f6c746d41ad7a95ef1f28d1cccf244649) Reviewed-by: Qt Cherry-pick Bot <cherrypick_bot@qt-project.org>
This commit is contained in:
parent
c304f45b54
commit
e38e517dfc
@ -2042,6 +2042,12 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
a \l{default-constructed value} into the hash with the \a key, and
|
||||
returns a reference to it.
|
||||
|
||||
//! [qhash-iterator-invalidation-func-desc]
|
||||
\warning Returned iterators/references should be considered invalidated
|
||||
the next time you call a non-const function on the hash, or when the
|
||||
hash is destroyed.
|
||||
//! [qhash-iterator-invalidation-func-desc]
|
||||
|
||||
\sa insert(), value()
|
||||
*/
|
||||
|
||||
@ -2125,12 +2131,16 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns an \l{STL-style iterators}{STL-style iterator} pointing to the first item in
|
||||
the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa constBegin(), end()
|
||||
*/
|
||||
|
||||
/*! \fn template <class Key, class T> QHash<Key, T>::const_iterator QHash<Key, T>::begin() const
|
||||
|
||||
\overload
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
/*! \fn template <class Key, class T> QHash<Key, T>::const_iterator QHash<Key, T>::cbegin() const
|
||||
@ -2139,6 +2149,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the first item
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa begin(), cend()
|
||||
*/
|
||||
|
||||
@ -2147,6 +2159,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the first item
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa begin(), constEnd()
|
||||
*/
|
||||
|
||||
@ -2156,6 +2170,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the first key
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyEnd()
|
||||
*/
|
||||
|
||||
@ -2164,12 +2180,16 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns an \l{STL-style iterators}{STL-style iterator} pointing to the imaginary item
|
||||
after the last item in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa begin(), constEnd()
|
||||
*/
|
||||
|
||||
/*! \fn template <class Key, class T> QHash<Key, T>::const_iterator QHash<Key, T>::end() const
|
||||
|
||||
\overload
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
/*! \fn template <class Key, class T> QHash<Key, T>::const_iterator QHash<Key, T>::constEnd() const
|
||||
@ -2177,6 +2197,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
item after the last item in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa constBegin(), end()
|
||||
*/
|
||||
|
||||
@ -2186,6 +2208,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
item after the last item in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa cbegin(), end()
|
||||
*/
|
||||
|
||||
@ -2195,6 +2219,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
item after the last key in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyBegin()
|
||||
*/
|
||||
|
||||
@ -2204,6 +2230,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns an \l{STL-style iterators}{STL-style iterator} pointing to the first entry
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyValueEnd()
|
||||
*/
|
||||
|
||||
@ -2213,6 +2241,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns an \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
entry after the last entry in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyValueBegin()
|
||||
*/
|
||||
|
||||
@ -2222,6 +2252,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the first entry
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyValueEnd()
|
||||
*/
|
||||
|
||||
@ -2231,6 +2263,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the first entry
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyValueBegin()
|
||||
*/
|
||||
|
||||
@ -2240,6 +2274,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
entry after the last entry in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyValueBegin()
|
||||
*/
|
||||
|
||||
@ -2249,6 +2285,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
entry after the last entry in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa constKeyValueBegin()
|
||||
*/
|
||||
|
||||
@ -2268,6 +2306,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
references to the ones in the hash. Specifically, mutating the value
|
||||
will modify the hash itself.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa QKeyValueIterator
|
||||
*/
|
||||
|
||||
@ -2285,6 +2325,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
|
||||
\snippet code/src_corelib_tools_qhash.cpp 15
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa remove(), take(), find()
|
||||
*/
|
||||
|
||||
@ -2304,12 +2346,16 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
|
||||
\snippet code/src_corelib_tools_qhash.cpp 16
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa value(), values()
|
||||
*/
|
||||
|
||||
/*! \fn template <class Key, class T> QHash<Key, T>::const_iterator QHash<Key, T>::find(const Key &key) const
|
||||
|
||||
\overload
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
/*! \fn template <class Key, class T> QHash<Key, T>::const_iterator QHash<Key, T>::constFind(const Key &key) const
|
||||
@ -2321,6 +2367,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
If the hash contains no item with the \a key, the function
|
||||
returns constEnd().
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa find()
|
||||
*/
|
||||
|
||||
@ -2332,6 +2380,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
is replaced with \a value.
|
||||
|
||||
Returns an iterator pointing to the new/updated element.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
/*!
|
||||
@ -2343,6 +2393,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
construction.
|
||||
|
||||
Returns an iterator pointing to the new element.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
|
||||
@ -2367,12 +2419,16 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
|
||||
Returns a pair of iterators delimiting the range of values \c{[first, second)}, that
|
||||
are stored under \a key. If the range is empty then both iterators will be equal to end().
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
/*!
|
||||
\fn template <class Key, class T> std::pair<const_iterator, const_iterator> QMultiHash<Key, T>::equal_range(const Key &key) const
|
||||
\overload
|
||||
\since 5.7
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
/*! \typedef QHash::ConstIterator
|
||||
@ -2970,6 +3026,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
|
||||
Returns an iterator pointing to the new/updated element.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa insert()
|
||||
*/
|
||||
|
||||
@ -2984,6 +3042,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
|
||||
Returns an iterator pointing to the new element.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa replace()
|
||||
*/
|
||||
|
||||
@ -3002,6 +3062,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
|
||||
Returns an iterator pointing to the new element.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa insert
|
||||
*/
|
||||
|
||||
@ -3018,6 +3080,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
|
||||
Returns an iterator pointing to the new element.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa replace, emplace
|
||||
*/
|
||||
|
||||
@ -3084,6 +3148,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
If the hash contains multiple items with the \a key, this function returns
|
||||
a reference to the most recently inserted value.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa insert(), value()
|
||||
*/
|
||||
|
||||
@ -3236,12 +3302,16 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
|
||||
If the hash contains multiple items with the \a key and \a value, the
|
||||
iterator returned points to the most recently inserted item.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
/*!
|
||||
\fn template <class Key, class T> typename QMultiHash<Key, T>::const_iterator QMultiHash<Key, T>::find(const Key &key, const T &value) const
|
||||
\since 4.3
|
||||
\overload
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
/*!
|
||||
@ -3253,6 +3323,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
|
||||
If the hash contains no such item, the function returns
|
||||
constEnd().
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
/*! \fn template <class Key, class T> QMultiHash<Key, T>::iterator QMultiHash<Key, T>::begin()
|
||||
@ -3260,12 +3332,16 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns an \l{STL-style iterators}{STL-style iterator} pointing to the first item in
|
||||
the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa constBegin(), end()
|
||||
*/
|
||||
|
||||
/*! \fn template <class Key, class T> QMultiHash<Key, T>::const_iterator QMultiHash<Key, T>::begin() const
|
||||
|
||||
\overload
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
*/
|
||||
|
||||
/*! \fn template <class Key, class T> QMultiHash<Key, T>::const_iterator QMultiHash<Key, T>::cbegin() const
|
||||
@ -3274,6 +3350,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the first item
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa begin(), cend()
|
||||
*/
|
||||
|
||||
@ -3282,6 +3360,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the first item
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa begin(), constEnd()
|
||||
*/
|
||||
|
||||
@ -3291,6 +3371,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the first key
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyEnd()
|
||||
*/
|
||||
|
||||
@ -3299,6 +3381,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns an \l{STL-style iterators}{STL-style iterator} pointing to the imaginary item
|
||||
after the last item in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa begin(), constEnd()
|
||||
*/
|
||||
|
||||
@ -3312,6 +3396,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
item after the last item in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa constBegin(), end()
|
||||
*/
|
||||
|
||||
@ -3321,6 +3407,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
item after the last item in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa cbegin(), end()
|
||||
*/
|
||||
|
||||
@ -3330,6 +3418,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
item after the last key in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyBegin()
|
||||
*/
|
||||
|
||||
@ -3339,6 +3429,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns an \l{STL-style iterators}{STL-style iterator} pointing to the first entry
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyValueEnd()
|
||||
*/
|
||||
|
||||
@ -3348,6 +3440,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns an \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
entry after the last entry in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyValueBegin()
|
||||
*/
|
||||
|
||||
@ -3357,6 +3451,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the first entry
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyValueEnd()
|
||||
*/
|
||||
|
||||
@ -3366,6 +3462,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the first entry
|
||||
in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyValueBegin()
|
||||
*/
|
||||
|
||||
@ -3375,6 +3473,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
entry after the last entry in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa keyValueBegin()
|
||||
*/
|
||||
|
||||
@ -3384,6 +3484,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
Returns a const \l{STL-style iterators}{STL-style iterator} pointing to the imaginary
|
||||
entry after the last entry in the hash.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa constKeyValueBegin()
|
||||
*/
|
||||
|
||||
@ -3403,6 +3505,8 @@ size_t qHash(long double key, size_t seed) noexcept
|
||||
references to the ones in the hash. Specifically, mutating the value
|
||||
will modify the hash itself.
|
||||
|
||||
\include qhash.cpp qhash-iterator-invalidation-func-desc
|
||||
|
||||
\sa QKeyValueIterator
|
||||
*/
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user