我正在使用boost :: mpl对概念样本做一些证明,并且在理解lambda函数如何使用占位符方面遇到一些困难.
我意识到我可以在元函数类中包装元函数,以使更高阶的函数能够访问嵌套的apply函数,并且意识到可以通过使用允许占位符的元函数mpl :: lambda来避免这种努力.
这怎么实际工作?我的头脑围绕着喇叭和占位符在封面下实际做了很麻烦.
解决方法
请参阅
Boost.MPL manual:占位符是mpl :: arg< X>形式的元功能类.元功能类是包含应用元功能的类.
template <int N> struct arg; // forward declarations struct void_; template <> struct arg<1> { template < class A1,class A2 = void_,... class Am = void_> struct apply { typedef A1 type; // return the first argument }; }; typedef arg<1> _1
mpl :: lambda的工作是将占位符表达式转换为元函数类.这是通过嵌入像this这样的元功能类完成的:
template< typename X,typename Tag = unspecified > struct lambda { typedef unspecified type; };
如果x是通用形式X< a1,... an>中的占位符表达式,其中X是类模板,a1,… an是任意类型,嵌入的未指定类型f等价于
typedef protect< bind< quoten<X>,lambda<a1>::type,... lambda<an>::type > > f;
否则,f与X相同.应用元功能通过访问嵌入式类型来计算lambda表达式.
在MPL manual中,您可以查找保护,绑定和引用的定义.他们都是围绕他们的论据,尽可能延迟评估.