仿函数(函数对象)和STL算法

1仿函数可当作排序准则

程序员经常将某些class obect以有序的形式置于容器中或许你是 不能或不想反正你无法使用一般的operator<来对这些对象排序,你必须以某种特别规则通常基于某些成员函数此时仿函数派上用场例如:

Class Person

{

Public:

String firstname() const;

String lastname() const;

}

Class personsortCriterion

{

  Bool operator()(const Person& p1,const Person& p2)

{

    Return p1.lastname()<p2.lastname()||(!(p2.lastname()<p1.lastname()&&p1.firstname()<p2.fisrtname())

}

};

Int main()

{

Typedefset<Person,PersonsortCriterion>Personset;

Personset col;

 

}

2 拥有内部状态的仿函数

下面例子讲展示仿函数如何模拟哈书在同一时刻拥有多个状态

class IntSequence

{

private:

    intvalue;

public:

    IntSequence(intinitialValue):value(initialValue){}

    intoperator()(){

        returnvalue++;

    }

};

void main()

{

    list<int>col;

    intistart=1;

    generate_n(back_inserter(col),9,IntSequence(istart));

    for_each(col.begin(),col.end(),print);

    cout<<endl;

    generate(++col.begin(),--col.end(),IntSequence(istart));

    for_each(col.begin(),col.end(),print);

    cout<<endl;

    list<int>coll;

    IntSequence seq(istart);

    generate_n(back_inserter(coll),9,seq);

    for_each(coll.begin(),coll.end(),print);

    cout<<endl;

}

有两个办法可以从运用了仿函数的算法中的结果和反馈

1)  以by reference的方式传递仿函数

2)  运用for_each()算法的返回值

运用reference方式传递只需将template参数明白加以表示

Generate<back_insert_iterator<list<init>>,int,IntSequence&>(back_insert(col),4,seq)

For_each()的返回值

如果你使用的算法是for_each()那就不必大费周折的实作仿函数的引用计数版本来存取最终状态。For——each有独门绝技其他算法没有那就是可以返回其仿函数

class MeanValue

{

private:

    longnumber;

    longsum;

public:

    MeanValue():number(0),sum(0)

    {}

    voidoperator()(int elem)

    {

        number++;

        sum+=elem;

    }

    doublevalue()

    {

        returnstatic_cast<double>(sum)/static_cast<double>(number);

 

    }

};

void main()

{

    vector<int>col;

    for(inti=1;i<9;++i)

    {

        col.push_back(i);

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值