2017-11-24 22:16:29 +08:00
|
|
|
.. title:: clang-tidy - bugprone-inaccurate-erase
|
2015-12-23 01:36:49 +08:00
|
|
|
|
2017-11-24 22:16:29 +08:00
|
|
|
bugprone-inaccurate-erase
|
|
|
|
=========================
|
2015-08-28 02:10:07 +08:00
|
|
|
|
|
|
|
|
|
|
|
Checks for inaccurate use of the ``erase()`` method.
|
|
|
|
|
|
|
|
Algorithms like ``remove()`` do not actually remove any element from the
|
|
|
|
container but return an iterator to the first redundant element at the end
|
|
|
|
of the container. These redundant elements must be removed using the
|
|
|
|
``erase()`` method. This check warns when not all of the elements will be
|
|
|
|
removed due to using an inappropriate overload.
|
2019-05-08 20:02:31 +08:00
|
|
|
|
|
|
|
For example, the following code erases only one element:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
std::vector<int> xs;
|
|
|
|
...
|
|
|
|
xs.erase(std::remove(xs.begin(), xs.end(), 10));
|
|
|
|
|
|
|
|
Call the two-argument overload of ``erase()`` to remove the subrange:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
std::vector<int> xs;
|
|
|
|
...
|
|
|
|
xs.erase(std::remove(xs.begin(), xs.end(), 10), xs.end());
|