下面的代码再现了我对boost MPL库真的不了解的行为:
#include <boost/type_traits/is_same.hpp>
#include <boost/mpl/int.hpp>
#include <boost/mpl/plus.hpp>
using namespace boost;
int main() {
typedef mpl::int_<1> one;
typedef mpl::int_<2> two;
typedef mpl::int_<3> three;
// The following line breaks compilation...
// static_assert( is_same< mpl::plus<one,two>::type, three >::type::value, "Not the same type");
// ...while this works
static_assert( mpl::plus<one,two>::type::value == three::value , "Not the same value");
return 0;
}
我的问题是:为什么mpl::plus<one,two>::type
与three
的类型不同?
我在尝试解决第3章末尾的练习时遇到了这个问题
C++ Template Meta-Programming。我已经试图查看<boost/mpl/plus.hpp>
及其中的内容,但代码太复杂了,我无法理解。
答案 0 :(得分:5)
plus
的返回类型仅保证为整数常量。您无法保证它的确切类型,因此您的断言允许失败。
具体类型如下:
mpl::plus<one,two>::type == mpl_::integral_c<int, 3>
three == foo<mpl_::int_<3> >
这是不直观的。一个问题是plus<int_, int_>
理论上可以返回integral_c
,其中第一个参数具有更大的容量,然后int_
以防溢出。
对于调试,type printer
可能很有用:
template<typename> print; // undefined instantiation leads to error with name
print<three> x; // nice error message