Details
-
Bug
-
Resolution: Done
-
P2: Important
-
5.15.6
-
None
-
-
713967ae30 (qt/qtbase/dev) 713967ae30 (qt/tqtc-qtbase/dev) 809f6c3637 (qt/qtbase/6.3) 809f6c3637 (qt/tqtc-qtbase/6.3) 510b82ea30 (qt/qtbase/6.2) 510b82ea30 (qt/tqtc-qtbase/6.2) 740c9e96de (qt/tqtc-qtbase/5.15)
Description
In the documentation of QListIterator (https://doc.qt.io/qt-5/qlistiterator.html#details)
we can see :
QList<float> list; ... QListIterator<float> i(list); while (i.hasNext()) qDebug() << i.next();
or
QListIterator<float> i(list); i.toBack(); while (i.hasPrevious()) qDebug() << i.previous();
These codes fail depending on the debug level. If "*.debug=false", methods next() or previous() are not executed in the examples above. And the loop is infinite if there is at least one element.
So we have to prefer :
QList<float> list; ... QListIterator<float> i(list); while (i.hasNext()) { float value = i.next(); qDebug() << value; }
and
QListIterator<float> i(list); i.toBack(); while (i.hasPrevious()) { float value = i.previous() qDebug() << value; }
Attachments
For Gerrit Dashboard: QTBUG-97535 | ||||||
---|---|---|---|---|---|---|
# | Subject | Branch | Project | Status | CR | V |
388789,4 | Doc: Make QListIterator snippets more robust | dev | qt/qtbase | Status: MERGED | +2 | 0 |
390402,2 | Doc: Make QListIterator snippets more robust | 6.3 | qt/qtbase | Status: MERGED | +2 | 0 |
390403,2 | Doc: Make QListIterator snippets more robust | 6.2 | qt/qtbase | Status: MERGED | +2 | 0 |
390412,3 | Doc: Make QListIterator snippets more robust | tqtc/lts-5.15 | qt/tqtc-qtbase | Status: MERGED | +2 | 0 |