for_each算法函数

转: http://www.cnblogs.com/lancidie/archive/2010/12/02/1894099.html

for_each函数原形

template<class _InIt,

     class _Fn1> inline

     _Fn1 for_each(_InIt _First, _InIt _Last, _Fn1 _Func)

     {    // perform function for each element

     for (; _ChkFirst != _ChkLast; ++_ChkFirst)

         _Func(*_ChkFirst);

     return (_Func);

     }

(为了提高可读性,原形略有修改)

头文件:

<algorithm>

说明:

for_each 算法范围 [_First, _ Last中的每个元素调用函数_Fn1,并返回输入的参数 _Func。此函数不会修改序列中的任何元素。

用于删除std::list指针类型元素变量

STL标准模板库,容器类只负责管理容器元素本身,包括类对象或者指针类型变量;对于指针类型元素,STL容器类不会管理元素的内存分配及释放内存问题,请看以下一小段代码:

     // 定义用户列表

     std::list<CUserInfo*> m_users;

 

     // 添加元素

     CUserInfo * user1 = new CUserInfo();

     m_users.push_back(user1);

     // ...

 

     // 清空

     m_users.clear();

请注意,当调用users .clear()之后,将会导致程序内存泄露。

作为一个合格的程序,你立即就会想到以下方法:

     std::list<CUserInfo*>::iterator iter;

     for (iter=m_users.begin(); iter!=m_users.end(); iter++)

     {

         delete *iter;

     }

以上代码怎么看都不怎么顺眼,我们可以利用for_each算法函数实现类似功能:

先定义一个结构模板,用于删除模板对象的指针,代码如下:

struct DeletePtr

{

     template<typename T>

     void operator() (const T* ptr) const

     {

         if (ptr)

              delete ptr;

     }

};

然后修改前面的for()循环,代码如下:

     for_each(m_users.begin(),m_users.end(), DeletePtr());

m_users.clear();

最重要一点,定义了DeletePtr结构模板后,可以在不同的项目中重用。

如何应用于std::map

讲到这里,有些人可能开始有点不耐烦了,下面就直接给出代码:

struct DeletePair

{

     template<typename Ty1, typename Ty2>

     void operator() (const std::pair<Ty1, Ty2> &ptr) const

     {

         if (ptr.second)

              delete ptr.second;

     }

};

std::mapstd::list处理不一样,以下代码演示了如何在std::map中使用该模板:

     // 定义用户列表

     std::map<long, CUserInfo*> m_users;

 

 

     // 清空

     for_each(m_users.begin(), m_users.end(), DeletePair());

     m_users.clear();

总结

提供的DeletePtr和DeletePair结构模板,只是用于删除内存,功能并不强大;只是希望通过这二个例子,让读者可以学习到如何利用for_each实现更多的事情,比如循环调用某个类成员函数(下次提供源码例子)等。


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值