加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C 11中的高阶函数

发布时间:2020-12-16 03:11:24 所属栏目:百科 来源:网络整理
导读:我正在使用C 11中提供的新的匿名函数来编写一个通用的折叠函数,这里是我所拥有的: templatetypename TT foldl(std::functionT(T,T) f,T initial,std::vectorT items) { T accum = initial; for(typename std::vectorT::iterator it = items.begin(); it !=
我正在使用C 11中提供的新的匿名函数来编写一个通用的折叠函数,这里是我所拥有的:
template<typename T>
T foldl(std::function<T(T,T)> f,T initial,std::vector<T> items) {
    T accum = initial;
    for(typename std::vector<T>::iterator it = items.begin(); it != items.end(); ++it) {
        accum = f(accum,(*it));
    }
    return accum;
}

以下尝试使用它:

std::vector<int> arr;
arr.assign(8,2);
foldl([] (int x,int y) -> int { return x * y; },1,arr);

导致错误:

main.cpp:44:61: error: no matching function for call to 'foldl(main(int,char**)::<lambda(int,int)>,int,std::vector<int>&)'
main.cpp:44:61: note: candidate is:
main.cpp:20:3: note: template<class T> T foldl(std::function<T(T,T)>,T,std::vector<T>)
main.cpp:20:3: note:   template argument deduction/substitution failed:
main.cpp:44:61: note:   'main(int,int)>' is not derived from 'std::function<T(T,T)>'

在我看来,使用std ::函数不是正确的方法来定义f的类型.我该如何纠正?

解决方法

你的代码不是很通用.没有必要要求一个函数,矢量或任何类型的东西.一般来说,在C中,函数将在参数列表的末尾(对于lambdas尤其重要,因为它们可能很大).

所以这样做会更好(即:更标准)

template<typename Range,typename Accum>
typename Range::value_type foldl(const Range &items,const typename Range::value_type &initial,Accum f)
{
    typename Range::value_type accum = initial;
    for(const auto &val : items) {
        accum = f(accum,val);
    }

    return accum;
}

或者你可以只是use std::accumulate这是完全相同的事情.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读