linux社区爱心援助Linux认证系列教程业界动态站务新闻公司招聘网络学院网址大全LPI专题CISCO专题
设为首页
加入收藏
管理团队
JSP  
JAVA  
PERL  
 您的位置:首页 > 开发语言 > c/c++/c# >
栏目导栏
  php
  JSP
  ASP
  asp.net
  JAVA
  c/c++/c#
  perl
  JavaScript
  Basic
  Delphi
资料搜索
热门文章
·Windows/Linux下配置Eclipse+C
·c语言static与extern的用法
·VC++(Ctime日期函数)应用
·typedef struct和struct的区别
·C/C++对文件操作
·C常用算法程序实例-线性代数方
·C#发送Email邮件方法总结
·struct的初始化,拷贝及指针成
·C语言入门实例 switch使用
·c++二叉树实现源代码
·对初学者的建议:如何学习C语言
·C++ Builder 处理控件中的文本
·常用的BCB & Delphi 函数
·C++入门经典教程完全版01-引言
·C++ Builder 使用Canvas对象的
最新文章
·使用C/C++扩展Python
·C语言入门实例 switch使用
·在C#里实现DATAGRID的打印预览
·如何使用 Visual C# .NET 创建
·C#发送Email邮件方法总结
·一道C#面试题目引发的思考
·c语言艺术清屏
·c语言static与extern的用法
·大数的阶乘算法
·C#编码好习惯
·构造函数,复制构造函数
·typedef struct和struct的区别
·struct的初始化,拷贝及指针成
·超强的指针学习笔记推荐
·STL中erase方法对链表类容器的
Google
 
STL中erase方法对链表类容器的影响
[ 作者:  加入时间:2007-11-09 10:26:09  来自:Linux联盟收集整理 ]

STL中提供erase算法用于删除通用容器内中某一个或是某一区间内的数据.而且通用于vector, list包括一般的数组都可以使用.但对于一般性不支持随机访问的容器,比如list容器是用链表指针进行连接的类,在使用earse算法的时候要格外注意.

比如在C++ Primer中提供的一道练习,

请写一个程序使它接受下列定义aFNLinux联盟
int ia[] = { 0, 1, 1, 2, 3, 5, 8, 13, 21, 55, 89 };aFNLinux联盟
list<int> ilist( ia, ia+11 );aFNLinux联盟
用单个iterator 形式的erase()删除ilist 中所有奇数位置的元素.

对于该问题,不可直接使用如下方法:

list<int>::iterator p = ilist.begin();

for(int i = 0; p != ilist.end(); ++i, ++p)

       if(i % 2 == 0)   ilist.erase(p);

因为仔细分析一下不难发现,在++p动作是在erase方法调用以后在执行的,而++p在list容器类中其运算方法不像vector可随机访问容器类一样是进行简单+1操作,而是根据当前对象的指针指到下一对象,因此当erase方法调用后,p所引用的当前对象已被消灭,这样++p操作得到的结果就是p= null,然后程序非正常退出.

从上面看出,要解决这类问题,必须保留当前对象,直到确切的保存了当前对象所指向的下一对象的应用才可进行erase操作.

因此如下:

list<int>::iterator p = ilist.begin();aFNLinux联盟
 list<int>::iterator p1 = p;

 for(int i = 0; p != ilist.end(); ++i)aFNLinux联盟
       if(i % 2 == 0) {aFNLinux联盟
           p1 = p;       aFNLinux联盟
           ++p;aFNLinux联盟
         ilist.erase(p1);aFNLinux联盟
         }aFNLinux联盟
        else aFNLinux联盟
            ++p;

推而广之,在STL中任何关于以链表形式链接的容器类都必须注意在移除某些元素时所出现的++p失效的情况.

Linux联盟收集整理 ,转贴请标明原始链接,如有任何疑问欢迎来本站Linux论坛讨论
评论】【加入收藏夹】【 】【打印】【关闭
※ 相关链接
 ·用JSTL实现JSP应用程序快速开发  (2007-10-25 13:31:42)
 ·厂商各自为政 分裂影响Linux手机发展  (2007-09-24 10:44:38)
 ·重装WindowsXP而不影响Ubuntu Linux系统  (2007-07-30 09:56:16)
 ·RMAN备份恢复之归档日志对BLOCKRECOVER的影响  (2007-06-20 10:56:36)
 ·认识那些影响Oracle系统性能初始化参数  (2007-06-04 11:59:54)
 ·影响MySQL中mysqld安全的四个选项  (2007-04-30 10:06:50)
 ·Linux内核可装载模块对设备驱动的影响  (2007-04-03 10:18:28)
 ·Oracle中空间管理对系统性能的影响  (2007-03-06 13:25:59)
 ·Oracle中PL/SQL编程对系统性能的影响  (2007-01-25 11:49:00)
 ·关于影响Oracle汉字显示的字符集分析  (2007-01-05 12:16:13)