Big*_*ion 1 c++ implicit-conversion variadic-templates c++11
如何检查可变参数模板声明中的所有类型都可以转换为size_t:
// instantiate only if extents params are all convertible to size_t
template<typename T, size_t N>
template<typename... E>
Array<T,N>::Array(E... extents) {
constexpr size_t n = sizeof...(extents);
static_assert(n == N, "Dimensions do not match");
// code for handling variadic template parameters corresponding to dimension sizes
}
Run Code Online (Sandbox Code Playgroud)
具有以下用法:
Array<double, 2> a(5,6); // OK 2-D array of 5*6 values of doubles.
Array<int, 3> a(2,10,15) // OK 3-D array of 2*10*15 values of int.
Array<int, 2> a(2, "d") // Error: "d" is not a valid dimension and cannot be implicitly converted to size_t
Run Code Online (Sandbox Code Playgroud)
这是类似的问题: 检查可变参数模板声明中的参数类型
在Columbo出色的all_true技巧的帮助下,这是一件轻而易举的事情:
template <bool...> struct bool_pack;
template <bool... v>
using all_true = std::is_same<bool_pack<true, v...>, bool_pack<v..., true>>;
template <class... Args>
std::enable_if_t<
all_true<std::is_convertible<Args, std::size_t>{}...>{}
> check(Args... args) {}
Run Code Online (Sandbox Code Playgroud)
在特定情况下,Check是构造函数:
template<typename... Args, class = std::enable_if_t<all_true<std::is_convertible<Args, std::size_t>{}...>{}>>
explicit Check(Args... args) {}
Run Code Online (Sandbox Code Playgroud)