我试图弄清楚如何使用boost:hana在编译时转换整数常量列表。
我的列表为:
constexpr auto vals = hana::to<hana::tuple_tag>(hana::range_c<int, 0, 3>);
我想申请这个功能:
constexpr auto Pow2(int i) { return 1 << i; }
然而
constexpr auto res = hana::transform(list, Pow2);
生成res hana::tuple<int, int, int>
的类型。我没有看到如何将参数移动到lambda到hana::int_c
的模板参数
// Compiler error: Non-type template argument is not a constant expression
constexpr auto Pow2(int i)
{
return hana::int_c<1 << i>{};
}
答案 0 :(得分:4)
在......
constexpr auto Pow2(int i) { return 1 << i; }
... i
是运行时整数。它不是“编译时友好”参数,因为它的值不会存储为其类型的一部分。您应该传递int_
代替:
template <int X>
constexpr auto Pow2(hana::int_<X>) { return hana::int_c<1 << X>; }
用法:
constexpr auto vals = hana::to<hana::tuple_tag>(hana::range_c<int, 0, 3>);
constexpr auto res = hana::transform(vals, [](auto x){ return Pow2(x); });
static_assert(std::is_same_v<
std::decay_t<decltype(res)>,
hana::tuple<hana::int_<1>, hana::int_<2>, hana::int_<4>>
>);
显然,你也可以用lambda做到这一点。此外,boost::hana::int_
有operator<<
重载,返回int_
:
hana::transform(vals, [](auto x){ return hana::int_c<1> << x; });