stl循环删除

struct st_data
{
    st_data(int i) : id(i)    {}

    int  id;
};

对于STL标准序列容器vector/deque/list(以vector为例)

当我们需清空容器vector<st_data*> vec时, 只需简单循环遍历即可

    for (auto it = vec.begin(); it != vec.end(); ++it)
    {
        delete (*it);
        *it = nullptr;
    }
    vec.clear();

但如果想删除所有id%2 == 0的所有元素呢?

首先想到的是:

    for (auto it = vec.begin(); it != vec.end(); ++it)
    {
        st_data *ptr = *it;
        if (ptr->id % 2 == 0)
        {
            vec.erase(it);
            delete ptr;
            ptr = nullptr;
        }
    }

千万不要! 因为当容器的一个元素被删除时, 指向那个元素的所有迭代器也都全部失效了.

正确方法如下:

    for (auto it = vec.begin(); it != vec.end();)
    {
        st_data *ptr = *it;
        if (ptr->id % 2 == 0)
        {
            it = vec.erase(it);
            delete ptr;
            ptr = nullptr;
        }
        else
        {
            ++it;
        }
    }

注:若为标准关联容器, 则采取不同的策略

对于map<int, st_data*> mpData; 正确使用方法为:

    map<int, st_data*> mpData;
    for (auto it = mpData.begin(); it != mpData.end();)
    {
        st_data *ptr = it->second;
        if (ptr->id % 2 == 0)
        {
            mpData.erase(it++);
        }
        else
        {
            ++it;
        }
    }

时间: 2024-08-09 19:22:05

stl循环删除的相关文章

for循环删除集合陷阱

首先看下面的代码: import java.util.LinkedList;import java.util.List; public class DeleteCollection {        public static void main(String[] args) {        List<String> list = new LinkedList<String>();        list.add("a");        list.add(&

循环删除list中多个元素

错误的做法: for(int i= 0;i<list.size();i--){ for(int j= 0; j<list2.size();j++){ if(list.get(i).contains(list2.get(j))){ list.remove(i); } } } 结果:Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: -1 因为在你删除元素的同事list.size()在变小,这

php循环删除文件目录及文件

删除文件及目录: 1 //循环删除目录和文件函数 2 function delDirAndFile( $dirName ) 3 { 4 if ( $handle = opendir( "$dirName" ) ) { 5 while ( false !== ( $item = readdir( $handle ) ) ) { 6 if ( $item != "." && $item != ".." ) { 7 if ( is_di

约瑟夫问题 算法很简单保证每隔人都能看懂用数组实现 利用循环删除数组中的元素

#include<iostream> using namespace std; const int size = 1000; void ArrDel() { int arr[size]; //循环结束标志,一直循环到数组中只剩下最后一个元素结束 int currentNum = size; int count = 0; for (int k = 0; k < size; k++) { arr[k] = k; } //currentNum==1表示数组中只剩下最后一个元素 是循环结束的标志

STL——遍历 删除 set 元素

==================================声明================================== 本文版权归作者所有. 本文原创,转载必须在正文中显要地注明作者和出处,并保证文章(包括本声明)的完整性. 未经作者授权请勿修改(包括本声明),保留法律追究的权利. 未经作者授权请勿用于学术性引用. 未经作者授权请勿用于商业出版.商业印刷.商业引用以及其他商业用途. 本文不定期修正完善,为保证内容正确,建议移步原文处阅读. 本文链接:http://www.c

go语言从零学起(三)--list循环删除元素(转载)

本篇系转载 在使用go的container/list的package时,你可能会无意间踩一个小坑,那就是list的循环删除元素. list删除元素,直观写下来的代码如下: package main import ( "container/list" "fmt" ) func main() { //初始化一个list l := list.New() l.PushBack(1) l.PushBack(2) l.PushBack(3) l.PushBack(4) fmt.

Python--增量循环删除MySQL表数据

需求场景: 有一业务数据库,使用MySQL 5.5版本,每天会写入大量数据,需要不定期将多表中“指定时期前“的数据进行删除,在SQL SERVER中很容易实现,写几个WHILE循环就搞定,虽然MySQL中也存在类似功能,怎奈自己不精通,于是采用Python来实现 话不多少,上脚本: # coding: utf-8 import MySQLdb import time # delete config DELETE_DATETIME = '2016-08-31 23:59:59' DELETE_RO

循环删除DataTable.Row中的多行问题

在C#中,如果要删除DataTable中的某一行,大约有以下几种办法: 1,使用DataTable.Rows.Remove(DataRow),或者DataTable.Rows.RemoveAt(index):可以直接删除行 2,datatable.Rows[i].Delete().Delete()之后需要datatable.AccepteChanges()方法确认完全删除,因为Delete()只是将相应列的状态标志为删除,还可以通过datatable.RejectChanges()回滚,使该行取

JS实现循环删除数组中元素的方法介绍

这篇文章主要给大家介绍了关于Javascript循环删除数组中元素的几种方法,文中给出了详细的示例代码供大家参考学习,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧. 本文主要跟大家分享了关于Javascript循环删除数组中元素的几种方法,分享出来供大家参考学习,下面来看看详细的介绍: 发现问题 大家在码代码的过程中,经常会遇到在循环中移除指定元素的需求.按照常规的思路,直接一个for循环,然后在循环里面来个if判断,在判断中删除掉指定元素即可.但是实际情况往往不会像预想的那样顺利