c – Lambda函数作为构造函数中std :: function的默认参数
发布时间:2020-12-16 05:02:58 所属栏目:百科 来源:网络整理
导读:我想在类的构造函数中为functor参数设置一个默认仿函数.作为一个最小的例子,我提出了一个应该作为过滤器服务器的类,它过滤类型为T的元素,如果过滤器函数返回true.过滤器函数应该在构造函数中提供,默认为“accept all”过滤器函数: templateclass Tclass Fil
我想在类的构造函数中为functor参数设置一个默认仿函数.作为一个最小的例子,我提出了一个应该作为过滤器服务器的类,它过滤类型为T的元素,如果过滤器函数返回true.过滤器函数应该在构造函数中提供,默认为“accept all”过滤器函数:
template<class T> class Filter { public: typedef std::function<bool(const T&)> FilterFunc; Filter(const FilterFunc & f = [](const T&){ return true; }) : f(f) { } private: FilterFunc f; }; 我实例化模板类,如下所示: int main() { Filter<int> someInstance; // No filter function provided (<-- line 19) } 但是,gcc 4.7 doesn’t seem to like this piece of code: prog.cpp: In constructor ‘Filter<T>::Filter(const FilterFunc&) [with T = int; Filter<T>::FilterFunc = std::function<bool(const int&)>]’: prog.cpp:19:17: internal compiler error: in tsubst_copy,at cp/pt.c:12141 Please submit a full bug report,with preprocessed source if appropriate. See <file:///usr/share/doc/gcc-4.7/README.Bugs> for instructions. Preprocessed source stored into /home/g9i3n9/cc82xcqE.out file,please attach this to your bugreport. 怎么了?我的代码标准是否符合标准(因此GCC在这里真的有问题,或者没有实现这个)或者我做错了什么? 作为一种解决方法,我目前使用默认构造的std :: function并且只调用它(我想要调用它),如果它已设置: Filter(const FilterFunc & f = FilterFunc) : f(f) { } // When using it: void process() { if (!f || f(someItem)) { // <-- workaround } } 解决方法
这是一个错误:编译器在处理源代码时崩溃或发生致命的内部错误,并且消息本身正在邀请您将错误视为:
这是另一种可能的解决方法: template<class T> class Filter { public: typedef std::function<bool(const T&)> FilterFunc; Filter() { } Filter(FilterFunc const& f) : f(f) { } private: FilterFunc f = [](const T&){ return true; }; }; 作为另一种选择,GCC支持委托构造函数,您可能需要考虑: #include <functional> template<class T> class Filter { public: typedef std::function<bool(const T&)> FilterFunc; Filter() : Filter([](const T&){ return true; }) { } Filter(FilterFunc const& f) : f(f) { } private: FilterFunc f; }; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |